Ребят, всем ку. Кто может подсказать, как грамотно все организовать. Есть

два микросервиса, условно
channels и ads
каждый микросервис пишет в свою коллекцию

в сервис ads приходит запрос, на получение списка объявлений
/api/v1/ads/list

в самой функции, мне нужно одним запросом сходить в коллекцию channels и собрать каналы по фильтрам gt,lt
крч, допустим получаю массив из 20 элементов
потом же мне нужно получить информацию, связанную именно с деталями объявления для каждого канала (коллекция ads)

это нормальная практика:
- одним запросом получаю список каналов
- потом в for range для каждого канала делаю индивидуальный запрос на получение инфы. Тоесть если в списке 20 каналов (которые достал одним запросом)
после придется делать еще 20 запросов, что бы получить дополнительную информацию для каждого канала

Это вообще здоровая практика? Или сервер сразу просядет при повышении rps, здесь стоит применить что-то типа агрегации или пайплайнов?

в итоге мне нужно собрать примерно следующую структуру
{
"ads": [
{
"channel_id": 1, // получаю из коллекции channels
"conditions": [] // получаю из коллекции ads
},
{
"channels_id": 2,
"conditions": []
},
{
"channel_id": 3,
"conditions": []
}
]
}


список из channel_id получаю одним запросом, но потом для каждого мне нужно забрать conditions из другой коллекции по фильтру channel_id
тоесть это одним запросом уже не сделать

или может в в монге можно сделать db.ads.find({"_id": [1, 2, 3] ]}) ?

объяснил как мудак, понимаю))))
но может кто-то сможет просвятить?)

5 ответов

13 просмотров

может вместо 20-ти запросов сформировать фильтр по массиву $in? тогда будет один запрос

"или может в в монге можно сделать db.ads.find({"_id": [1, 2, 3] ]}) ?", да, только вот так db.ads.find({"_id": {$in: [1, 2, 3]}})

t- Автор вопроса
Alexandr
"или может в в монге можно сделать db.ads.find({"_...

а если id-шников много будет, как это будет работать? например при 1000 идшников монга будет на каждый запрос обходить эти id-шники или по умному как нибудь разобьет на два запроса и конкуретно их выполнит и потом заджоинит результат? интересно как это в изнанке работает)

Вам нужен $lookup

t
а если id-шников много будет, как это будет работа...

На каждый запрос? Немного не понял, запрос то ведь один

Похожие вопросы

Обсуждают сегодня

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
1. https://www.kaggle.com/code/ahmadrezagholami2001/housing-estimation-linear-regression 2. https://www.kaggle.com/code/ahmadrezagholami2001/uncovering-quality-in-wines-logis...
Ahmadreza
1
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Карта сайта