Недавно делал быстрый прототип асинхронного приложения в котором требовалось вызывать много синхронного кода. Да, я знаю, что это не лучший дизайн, но нужно было быстрое решение на один процесс и без очередей. Поэтому я выполнял код в потоках.
Выглядело это примерно так:
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
🇷🇺#ALRS
"Алроса" изучает золотоносные потенциальные объекты в Магаданской и Иркутской областях, Хабаровском крае и Чукотском автономном округе как для самостоятельной разработки, так и совместно с партнерами, рассказал в интервью РИА Новости главный геолог "Алросы" Роман Желонкин
mt в max
Алмазно-бриллиантовый рынок третий год остается в состоянии спада, несмотря на первые признаки оживления в сегменте крупных и редких камней — Forbes #ALRS
Главная проблема — падение спроса на массовый сегмент, прежде всего на камни весом до двух карат.
Дополнительное давление оказывает ситуация в Индии, где сосредоточено около 90% мировых гранильных мощностей.
Еще один фактор — конкуренция со стороны искусственных алмазов.
Читать далее
👉https://smartlab.news/i/184522
мы в max
АЛРОСА увеличила цены на 6–9% на значительную часть своей продукции из-за дефицита крупных камней и логистических сложностей, вызванных ситуацией на Ближнем Востоке — Ъ #ALRS
Читать далее
👉https://smartlab.news/i/183482
мы в max
Мы сейчас видим первые признаки разворота на рынке необработанных алмазов — президент Всемирной федерации алмазных бирж (WFDB) Йорам Дваш #ALRS
"После недавней коррекции цен спрос начал укрепляться, и в некоторых сегментах снова наблюдается премия"
Президент WFDB указывает на то, что алмазная индустрия переживает один из самых тяжелых периодов за последние десятилетия.
Читать далее
👉https://smartlab.news/i/182770
мы в max
Искусственный бриллиант в 1 карат в опте можно купить за $70 — Сергей Тахиев, глава корпоративных финансов АЛРОСА на инвестиционном форуме ВТБ «РОССИЯ ЗОВЕТ! Санкт-Петербург»
Низкие цены на алмазы - следствие избыточных запасов, которые сложились в мире
Читать далее
👉https://smartlab.news/i/179399
#ALRS
Спрос на алмазы припал, но алмазы - не бананы, они не портятся — Сергей Тахиев, глава корпоративных финансов АЛРОСА на инвестиционном форуме ВТБ "РОССИЯ ЗОВЕТ! Санкт-Петербург"
Это миф, что молодежь не покупает люксовые товары, с ювелиркой бриллиантовой тоже все нормально
Читать далее
👉https://smartlab.news/i/179393
#ALRS
Рынок алмазной продукции сегодня сильно меняется за счет молодых потребителей, которые вместо натуральных камней предпочитают дешевые синтетические алмазы — РБК
Читать далее
👉https://smartlab.news/i/176666
#ALRS
Алроса нашла "елочную игрушку" и "щенка" под Архангельском
Прямо под Новый год алмазодобытчики обогатительной фабрики «Севералмаза» (входит в состав АЛРОСА) извлекли сразу два алмаза необычной формы – настоящие драгоценные ёлочные игрушки.
Первый алмаз весом чуть больше 17 карат формой напоминает елочный шар, а второй кристалл весом 2,7 карата – милого щенка.
Читать далее
👉https://smartlab.news/i/174426
#ALRS