172 похожих чатов

Ребят, добрый день! Хочу поинтересоваться следующим вопросом: Изпользую postgreql в

асинхронном варианте с 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; вижу что соединения открываются и копятся. Почему так?
Подскажите пожалуйста. Можно матом.

3 ответов

14 просмотров

Кажется вам лучше это спросить в чате по питону

Используйте with для конектов и транзакций, возможно из-за исключений текут конекты, которые не закрываются. А вообще в асинхронной приложении можно и пул конектов держать спокойно или пгбаунсер поставить.

John-Does Автор вопроса

Дорогие коллеги, всем спасибо кто уделил внимание. Проблема решена. Была ошибка в том что я делал ретурн до закрытия коннекта, соответственно происходил выход из функции и закрытие на происходило. Опечатался в одном месте, а потом размножил ошибку. Вопрос исправлен

Похожие вопросы

Обсуждают сегодня

Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
67
Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
40
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
27
В чем сила брат, в NASM или FASM?
Isaac Kleiner
18
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
11
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
Хтось використовував Vapor на Windows?
Jaroshevskii
15
Какое виндузовое сообщение приходит TTabSheet, что риэлайняться контролы на нем, даже у которых парент другой? Ситуация: открываю форму - кнопок нет, перелистываю на другой т...
Катерина Свиридова
7
Тут кста кто-нибудь NeoVim использует?
Simple Sorcerer
13
Карта сайта