Мне интересно, как лучше всего использовать глобальный httpx GlobalClient в Python 3.14. как правило, лучше всего иметь один глобальный цикл событий, но что, если мне нужно больше параллелизма или не блокировать более медленный ввод-вывод? У нас есть функции, которые используются как в FastAPI, так и в работниках celery, которые используют глобальный клиент событий. Нам нужна гибкость в использовании клиента из основного или альтернативного цикла событий, т. е. потока, чтобы улучшить загрузку ЦП, сохраняя при этом низкий уровень блокировки для определенной работы.
Я столкнулся с несколькими шаблонами и в других местах, где этот вопрос задавался:
В частности, я хотел бы квантовать накладные расходы, связанные с использованием выделенного цикла для клиента, и поделиться своими выводами здесь. Мы используем Celery, но я думаю, что aiotasks или обновление нашей синхронизации с асинхронностью могут решить проблемы, которые мы наблюдаем при обновлении до Python 3.14.
Подробнее здесь:
https://stackoverflow.com/questions/798 ... -practices