snippetsqlMajor
How to determine if there are [idle connections with] uncommitted transactions in PostgreSQL?
Viewed 0 times
postgresqluncommittedarewithconnectionsdeterminehowtransactionsthereidle
Problem
According to a comment on this question I asked about idle connections in PostgreSQL 9.2, some uncommitted transactions (possibly related to some of those idle connections) might cause
some performance issues.
What is a good way to determine if there are uncommitted transactions (bonus points if there is a way to know if the connection they're on is idle or not)?
Thanks very much!
some performance issues.
What is a good way to determine if there are uncommitted transactions (bonus points if there is a way to know if the connection they're on is idle or not)?
Thanks very much!
Solution
If you want to see how many idle connections you have that have an open transaction, you could use:
This will provide a list of open connections that are in the idle state, that also have an open transaction.
Beware that the state column is present only in PostgreSQL 9.2 and above.
Having said that, I cannot recreate an open connection in the idle state that has an open transaction. Perhaps someone else can provide details on how to do that.
select *
from pg_stat_activity
where (state = 'idle in transaction')
and xact_start is not null;This will provide a list of open connections that are in the idle state, that also have an open transaction.
Beware that the state column is present only in PostgreSQL 9.2 and above.
Having said that, I cannot recreate an open connection in the idle state that has an open transaction. Perhaps someone else can provide details on how to do that.
Code Snippets
select *
from pg_stat_activity
where (state = 'idle in transaction')
and xact_start is not null;Context
StackExchange Database Administrators Q#39721, answer score: 47
Revisions (0)
No revisions yet.