Каждый бэкенд-разработчик рано или поздно сталкивается с ситуацией, когда база данных MySQL внезапно ложится при резком пиковом наплыве пользователей. Классическая ошибка на старте — создавать новое независимое соединение с СУБД на каждый чих приложения, выполнять один короткий запрос и закрывать коннект. Когда на сайт одновременно залетают сотни людей, сервер моментально упирается в системный лимит max_connections и падает с ошибкой OperationalError: (1040, 'Too many connections'), попутно забивая всю доступную оперативную память.
Решение
В больших системах эту проблему перекладывают на тяжелые ORM вроде SQLAlchemy, но для локальных утилит, легковесных микросервисов и CLI-скриптов тащить за собой мегабайты чужих зависимостей ради одного пула коннектов это оверхед.
Мы разработали кастомный, легковесный асинхронный пул подключений на Python и драйвере aiomysql, который работает по принципу «микросервисной архитектуры» и изолирует нагрузку на стороне клиента. Вместо постоянного открытия и закрытия коннектов «туда-сюда», наш пул при старте инициализирует фиксированное количество постоянных соединений и держит их в асинхронной очереди asyncio.Queue.
Когда прилетает запрос, он берет готовое соединение из коробки, выполняет команду и возвращает его обратно. Если все соединения заняты — новый запрос не плодит нагрузку на RAM сервера, а покорно и незаметно для пользователя ждет своей очереди доли секунды. Чтобы защитить пул от утечек при возможных сбоях внутри запросов, вся логика завернута в строгий блок try...finally.
Для кого это создано
Данный пул разрабатывался не для гигантов с миллионными бюджетами на инфраструктуру. Целевая — легковесные асинхронные микросервисы, Telegram-боты на aiogram и стартапы, работающие на бюджетных VPS-серверах. Когда покупать дорогое железо нет бюджета, а бд MySQL падает от резких пиков, легковесный пул на чистом asyncio позволяет копеечному серверу без проблем выдерживать наплыв в сотни параллельных запросов. Сознательно отказываюсь от тяжелых ORM ради экономии ресурсов сервера и высокой скорости производительности.
Результаты стресс-теста
Для проверки софта под нагрузкой мы написали встроенный симулятор Highload-наплыва трафика Хабраэффект, который в реальном времени отправляет 300 одновременных запросов к локальной СУБД.
-
Тест БЕЗ пула подключений: СУБД моментально захлебывается и падает с системной ошибкой. MySQL уходит в глухую защиту от лавины параллельных сокетов, полностью отключая сайт для пользователей.

-
2. Тест С КАСТОМНЫМ ПУЛОМ (Размер пула = 5 коннектов): Все 300 параллельных запросов успешно обработаны без единой ошибки за 0.04 секунды. При этом общее время выполнения сокращается в разы, а потребление оперативной памяти сервера падает на 80%.

Весь проект полностью открыт, снабжен подробными комментариями и двуязычной README-инструкцией по быстрой установке и интеграции в ваши проекты ЗДЕСЬ (Если будет полезно, поддержите звездочкой). Каждый желающий может склонировать репозиторий, прописать конфиг своей локальной СУБД MySQL и лично проверить воспроизводимость результатов бенчмарка.
ссылка на оригинал статьи https://habr.com/ru/articles/1055024/