асинк фреймворке. Ходит с AsyncIOMotorClient в монгу, получает там существенную пачку данных.
После этого серверу нужно эти данные перебрать, взять какие-то определенные поля, чутка перформатировать (и это для каждого элемента), и после вернуть юзеру.
Проблема в том, что записей много, и перебор их в цикле вешает приложение, и отваливает остальные запросы.
Как лучше будет решить эту проблему?
Типа самые банальные идеи - обрабатывать каждый отдельный элемент через gather(),
или присвоить операции какой-нибудь Id и отдать в воркер, вернуть юзеру 202 с id и пусть ходит проверяет выполнение. Что было бы best practice? Не обязательно из этих двух, мб есть какой-то вариант ещё лучше.
Попробуй из монги тащить только нужное
А я и тащу только нужное, просто там формат не тот, и элементы нужно отдавать чуть в другом виде.
Это сколько у тебя элементов что оно так долго работает?
Обсуждают сегодня