Недавно делал быстрый прототип асинхронного приложения в котором требовалось вызывать много синхронного кода. Да, я знаю, что это не лучший дизайн, но нужно было быстрое решение на один процесс и без очередей. Поэтому я выполнял код в потоках.
Выглядело это примерно так:
from fastapi.concurrency import run_in_threadpool
async def execute(data: DataRequest) -> DataResponse:
try:
result = await run_in_threadpool(sync_function, data)
return DataResponse(data=result)
except Exception as e:
return DataResponse(
error=str(e),
success=False,
)
В общем работает нормально. Для всех вызовов под капотом используется общий тредпул, всё работает предсказуемо.
Но потребовалось изменить количество запускаемых в пуле потоков (по умолчанию создается 40 воркеров).
Так как дело происходит с FastAPI, делается это через lifespan используя настройки anyio:
import anyio
@asynccontextmanager
async def lifespan(app: FastAPI):
limiter = anyio.to_thread.current_default_thread_limiter()
limiter.total_tokens = 100
yield
# если вдруг нужно вернуть обратно
limiter.total_tokens = 40
Зачем менять количество воркеров?
- уменьшить, если оперативки мало (один тред занимает ~8мб)
- увеличить чтобы выдержать нагрузку
Если есть предложения получше при тех же вводных - предлагайте😉
#async
В прошедшие выходные 18.10. при поддержке Invoke ⚡️в Белом Колодце у наших друзей ДОГОНЯЙ36
прошла эндуро-гонка
Мощная трасса, грязь по колено и десятки райдеров, проверяющих себя на прочность!
#invokedrinks
SUMMER VIBES with INVOKE 🔊
Не знаем, как вы, но мы с Денисом уже сильно скучаем по лету, провожая первый месяц осени.
Когда энергии солнца перестает хватать – на помощь приходит invoke. Всегда с тобой, когда силы на нуле 💯
ph: Ignat Ikonnikov
#invokedrinks
Профессиональная спортсменка по флоубордингу и вейксерфингу Екатерина Руднева показывает стильное катание по волнам с энергией мохито от invoke 🍋🟩
#invokedrinks
DROPLINE DOWNHILL, АРХЫЗ 🌳
Ребята опубликовали фото с недавней гонки в горах – Dropline Downhill Race 3. Какой же все-таки это красивый вид спорта, согласны?
📷Дмитрий Рындин
#invokedrinks
Сегодня в байк-парке Архыз проходит заключительный этап DropLine DH Race🏔️
Напоминаем, что Downhill Race – это соревнования по скоростному спуску на велосипедах, где каждый участник стартует индивидуально. Главная задача – проехать по трассе с наименьшим временем.
Вчера состоялись тренировочные заезды, сегодня в парке проходит квалификация. Завтра ожидаются финалы и мы наконец-то узнаем, кто станет победителем третьего этапа серии гонок по скоростному спуску в Архызе⚡️
#invokedrinks
FeRRUM в Воронеже – открыт!🪩
5 сентября в Воронеже состоялось торжественное открытие нового филиала фитнес-центра FeRRUM.
Гости мероприятия посетили мастер-классы, поучаствовали в конкурсах, а также познакомились с напитками @invokedrinks и спортивным питанием @rusfitnutrition.
Поздравляем ребят с открытием. Были рады разделить этот момент с вами ⚡️
#invokedrinks
ГУЛ МОТОРА, ВИЗГ ШИН и ДРАЙВ, от которого СЕРДЦЕ БЬЕТСЯ В ТАКТ💨
Добро пожаловать на второй ежегодный фестиваль SUETA CAR FEST. Уже в эту субботу соберем всех любителей автодвижения.
📍 Москва, Быково, площадка RDRC;
📎начало мероприятия в 10:00, заезд для участников – с 8:00.
Это будет день, наполненный невероятными эмоциями и крутым общением — так, как мы это любим! Тебя ждет топ-20 лучших проектов по тюнингу, топ-5 автоклубов, суперкубок RDRC, мото-шоу, дрифт-такси и заряд invoke 🔥
#invokedrinks