Недавно делал быстрый прототип асинхронного приложения в котором требовалось вызывать много синхронного кода. Да, я знаю, что это не лучший дизайн, но нужно было быстрое решение на один процесс и без очередей. Поэтому я выполнял код в потоках.
Выглядело это примерно так:
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
#orbitchemistry#questel#тестовыйдоступ
РЦНИ информирует о том, что до 20 сентября 2024 года открыт прием заявок на участие в тестовом доступе к ресурсу Orbit Chemistry module компании Questel.
Даты проведения тестового доступа с 30 сентября по 29 ноября 2024 года.
Ресурс будет полезен для специалистов по интеллектуальной собственности в области органической химии, фармацевтики и биологических наук.
Подробная информация о ресурсе и форма заявки на участие в тестовом доступе размещены на сайте Национальная подписка.
Изображение от freepik
#Questel#orbitchemistry#вебинар#тестовыйдоступ
Компания Questel приглашает на вебинар «Тренинг по химическому модулю Orbit Chemistry», организованный в поддержку тестового доступа к ресурсу Orbit Chemistry module.
Дата мероприятия: 17 октября 2024 года в 15:00 по московскому времени.
Ведущий вебинара, представитель компании Questel, продемонстрирует функциональные возможности модуля и особенности поиска данных в Orbit Chemistry.
Язык мероприятия: английский.
Регистрация на вебинар не требуется. Подключение по ссылке.
Описание вебинара и ссылка для подключения доступны также на нашем сайте в разделе Вебинары.
Medical illustrations by Storyset
Предлагаем ознакомиться с графиком вебинаров от ведущих международных издательств на ближайшую неделю:
📅25 октября 2023 в 11:00 и 21:00 (мск)
✅CAS | Вероятностные модели и их применение
Регистрация доступна по ссылке.
📅26 октября 2023 в 17:00 (мск)
✅Questel | Продвинутый тренинг по Orbit Intelligence
Регистрация доступна по ссылке.
📅26 октября 2023 в 18:00 (мск)
✅Springer Nature | Редактирование статьи онлайн
Регистрация доступна по ссылке.
#вебинар#исследования#электронныересурсы#наука#библиотека#публикации#CAS#Questel#SpringerNature
Предлагаем ознакомиться с графиком вебинаров от ведущих международных издательств на ближайшую неделю:
📅17 октября 2023 в 17:00 (мск)
✅AIP | Вероятностные модели и их применение
Регистрация доступна по ссылке.
📅 18 октября 2023 в 17:00 (мск)
✅Questel | Базовый тренинг по Orbit Intelligence
Регистрация доступна по ссылке.
📅18 октября 2023 в 19:00 (мск)
✅ACS | Сила химии: Передовые исследования в области антибиотиков и генной терапии
Регистрация доступна по ссылке.
#вебинар#исследования#электронныересурсы#наука#библиотека#публикации#ACS#AIP#Questel
#CABI#CEPIEC#CNKI#Questel#Orbit#SAGE#тестовыйдоступ
Российский центр научной информации напоминает, что продолжается приём заявок на участие в тестовом доступе к научным информационным ресурсам в рамках централизованной (национальной) подписки.
По ссылкам, приведенным ниже можно ознакомиться с описанием каждого ресурса и заполнить форму заявки для включения организации в перечень участников тестового доступа.
Электронные ресурсы в области сельского хозяйства и наук о жизни, социальных, общественных и естественных наук (приём заявок – до 13 сентября 2024 года):
⚫️CABI. Коллекция баз данных – содержит научную информацию в области сельскохозяйственных наук и наук о жизни.
⚫️CEPIEC. Коллекция полнотекстовых баз данных – в базе собраны исследования аналитических центров, научные и статистические данные способствующие изучению и пониманию современного Китая.
⚫️CNKI. Коллекция полнотекстовых баз данных – включает в себя публикации китайских и зарубежных академических периодических изданий, докторские и магистерские диссертаций, а также издания университетов и научно-исследовательских институтов.
Электронные ресурсы в области химии, машиностроения и инженерных наук (приём заявок – до 20 сентября 2024 года):
⚫️Questel. Ресурс Orbit Chemistry module – модуль, интегрированный в платформу Orbit Intelligence, предназначенный для поиска молекул в более чем 75 миллионах патентных документах.
⚫️SAGE Publications. Полнотекстовая коллекция журналов IMechE Journal Collection – коллекция журналов, охватывающая широкий спектр областей машиностроения и инженерных наук.
Image by tippapatt from Adobe Stock