Недавно делал быстрый прототип асинхронного приложения в котором требовалось вызывать много синхронного кода. Да, я знаю, что это не лучший дизайн, но нужно было быстрое решение на один процесс и без очередей. Поэтому я выполнял код в потоках.
Выглядело это примерно так:
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
Teno Afrika — Amapiano Selections (Awesome Tapes from Africa, 2020)
#amapiano#kwaito#deep_house#South_Africa
Стиль амапиано появился в середине 2010-х годов благодаря творчеству десятков молодых продюсеров из пригорода Гаутенга и быстро распространился через социальные сети. Он стал одним из самых актуальных жанров хаус-музыки в Южной Африке, объединив воедино различные музыкальные влияния, распространенные в округе Гаутенга. В нем можно услышать джазовые клавишные; басовые синтезаторы из квайто, популяного стиля африканского хауса; синтезаторы из дип-хауса; темп южно-африканского хауса конца 90-х. Светлая атмосфера и безжалостные барабаны амапиано передают южно-африкансий городской ритм, а ностальгические элементы, возможно, являются ключом к широкому успеху. 21-летний продюсер Тено Африка включил всю многогранность амапиано в свой дебют.
Spotify | AppleMusic | Bandcamp
Montparnasse Musique — Montparnasse Musique (Ben Bella Jazz, 2021)
#electronic#kwaito#gqom#techno#tribal#house#Congo#France
Montparnasse Musique — проект алжирско-французского продюсера Наджиба Бен Беллы, большого любителя африканского аутентичного звука, и южноафриканского диджея Aero Manyelo, адепт современного Йоханнесбурга, его афрохауса, техно, гком и кваито. Дуэт образовался после случайной встречи на вокзале Монпарнас в Париже, когда Aero Manyelo гастролировал с панафриканским коллективом Batuk. Cвой одноименный дебютный EP межконтинентальный дуэт записал при участии конголезских групп Kasai Allstars, Konono Nº1, Mbongwana Star и Basokin.
Spotify | AppleMusic | Bandcamp
Bulawayo Kwela, Elliot Phiri & David Tapfuma — Bulawayo Harare (Nyami Nyami, 2020)
#dancehall#dub#kwela#mbira#chimurenga#kwaito#Zimbabwe
Bulawayo Harare EP состоит из четырех треков, два из которых посвящены городу Булавайо, второму по величине в Зимбабве, а другие два — столице Зимбабве, Хараре.
Первую сторону пластинки открывает трек Mysterious Africa, переполненный отсылками к дабу и дэнсхоллу. Он исполнен зимбабвийской группой Bulawayo Kwela и спродюсирован Danalogue, участником британской группы The Comet Is Coming. Запись сопровождают слова зимбабвийского поэта Альберта Найати. Второй трек исполняет верный стилю квела Эллиот Фири, видимо один из участников Bulawayo Kwela.
Сторона Хараре представлена песней Дэвида Тапфума, записанной под аккомпанемент мбиры. Песня скорее всего имеет отношение к зимбабвийскому стилю популярной музыки чимуренга. Завершает пластинку ремикс песни Тапфума, сделанный Esa из Кейптауна, в котором слышно влияние южноафриканского хауса квайто.
Spotify | AppleMusic | Bandcamp | VK