асинхронном варианте с asyncpg. Использую колхозный вариант выполнения запросов(Нарим):
conn = await makeConnection()
res = await conn.fetchrow(f"SELECT * FROM test_table WHERE id = {id}")
await conn.close()
return res
Т.е. в каждом методе который обращается к бд я открываю коннект выполняю запрос, закрываю коннект.
Через какое то время ловлю asyncpg.exceptions.TooManyConnectionsError: sorry, too many clients already.
Посмотрел select count(*) from pg_stat_activity; вижу что соединения открываются и копятся. Почему так?
Подскажите пожалуйста. Можно матом.
Кажется вам лучше это спросить в чате по питону
Используйте with для конектов и транзакций, возможно из-за исключений текут конекты, которые не закрываются. А вообще в асинхронной приложении можно и пул конектов держать спокойно или пгбаунсер поставить.
Дорогие коллеги, всем спасибо кто уделил внимание. Проблема решена. Была ошибка в том что я делал ретурн до закрытия коннекта, соответственно происходил выход из функции и закрытие на происходило. Опечатался в одном месте, а потом размножил ошибку. Вопрос исправлен
Обсуждают сегодня