You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Do you use a PostgreSQL SaaS? If so, which? Can you reproduce
the issue with a local PostgreSQL install?: RDS, and yes
Python version: 3.12.6
Platform: MacOS and Linux
Do you use pgbouncer?: No
Did you install asyncpg with pip?: No, poetry
If you built asyncpg locally, which version of Cython did you use?: n/a
Can the issue be reproduced under both asyncio and uvloop?: Have not tried. Happy to if you think it would be beneficial
Spinning out of #1138 (comment) because it feels like a different discussion.
I'm running a FastAPI service that connects to AWS RDS, and needs to refresh credentials every 15 minutes. Normally, the type introspection queries don't take up much time because they run once per connection, but I have a lot of churn in my connection pool so run them a decent number of times. Recently I'm seen more traffic and thus more connections being created, and with more connections, the more often we're likely to see slow queries on things that are normally fast.
At a very high level, my service is set to connect to the database with:
Even abnormally slow type introspection queries aren't horrible but they are noticeable, as in the example below these 2 queries took more than 50% of the service's total response time.
Debugging locally a little with command: ["postgres", "-c", "log_statement=all"] in my docker-compose.yml, I can see what type asyncpg needs to examine:
2024-11-01 20:52:52.239 UTC [491] LOG: execute __asyncpg_stmt_1__: SELECT
t.oid,
t.typelem AS elemtype,
t.typtype AS kind
FROM
pg_catalog.pg_type AS t
WHERE
t.oid = $1
2024-11-01 20:52:52.239 UTC [491] DETAIL: parameters: $1 = '114'
2024-11-01 20:52:52.240 UTC [491] LOG: execute __asyncpg_stmt_2__: SELECT
t.oid,
t.typelem AS elemtype,
t.typtype AS kind
FROM
pg_catalog.pg_type AS t
WHERE
t.oid = $1
2024-11-01 20:52:52.240 UTC [491] DETAIL: parameters: $1 = '3802'
These correspond to the JSON and JSONB types, respectively, not even custom types.
The actual question: how can I pre-register the JSON and JSONB types in each connection so I don't have to keep running the introspection query? I've tried the json_{de,}serializer argument to the SQLAlchemy engine, as well as trying to hook into SQLAlchemy events to intercept connection creation and set the codecs.
The text was updated successfully, but these errors were encountered:
Hey team, would appreciate any thoughts on how this could be accomplished as we're seeing this problem scale with the number of connections. I took a little bit of a stab in the codebase here to see if I could get something working but believe I'm firmly out of my depth.
0.30.0
15.3
the issue with a local PostgreSQL install?: RDS, and yes
3.12.6
poetry
Spinning out of #1138 (comment) because it feels like a different discussion.
I'm running a FastAPI service that connects to AWS RDS, and needs to refresh credentials every 15 minutes. Normally, the type introspection queries don't take up much time because they run once per connection, but I have a lot of churn in my connection pool so run them a decent number of times. Recently I'm seen more traffic and thus more connections being created, and with more connections, the more often we're likely to see slow queries on things that are normally fast.
At a very high level, my service is set to connect to the database with:
Even abnormally slow type introspection queries aren't horrible but they are noticeable, as in the example below these 2 queries took more than 50% of the service's total response time.
Debugging locally a little with
command: ["postgres", "-c", "log_statement=all"]
in mydocker-compose.yml
, I can see what typeasyncpg
needs to examine:These correspond to the
JSON
andJSONB
types, respectively, not even custom types.The actual question: how can I pre-register the
JSON
andJSONB
types in each connection so I don't have to keep running the introspection query? I've tried thejson_{de,}serializer
argument to the SQLAlchemy engine, as well as trying to hook into SQLAlchemy events to intercept connection creation and set the codecs.The text was updated successfully, but these errors were encountered: