Saya menggunakan pernyataan dari halaman ini untuk melihat pemblokiran pertanyaan di Postgres
SELECT bl.pid AS blocked_pid,
a.usename AS blocked_user,
ka.query AS blocking_statement,
now() - ka.query_start AS blocking_duration,
kl.pid AS blocking_pid,
ka.usename AS blocking_user,
a.query AS blocked_statement,
now() - a.query_start AS blocked_duration
FROM pg_catalog.pg_locks bl
JOIN pg_catalog.pg_stat_activity a ON a.pid = bl.pid
JOIN pg_catalog.pg_locks kl ON kl.transactionid = bl.transactionid AND kl.pid != bl.pid
JOIN pg_catalog.pg_stat_activity ka ON ka.pid = kl.pid
WHERE NOT bl.granted;
Namun kueri terpotong sehingga saya biasanya tidak bisa melihat apa yang ada di WHERE
klausa yang membuat debugging masalah pemblokiran ini sangat sulit. Apakah ada pengaturan di mana saya dapat memberi tahu postgres untuk mencatat semua pertanyaanpg_stat_activity
sumber