在项目上遇到了postgres 死锁的问题,导致后面执行的脚本一直处理等待,后查询一些资料和询问了一些大神给与的定位问题思路:
1、执行下面脚本查找执行中的线程:
select pg_blocking_pids(pid), array_length(pg_blocking_pids(pid), 1) blocking_num, *
from pg_stat_activity
where query like '%sql%'
order by blocking_num desc NULLS LAST;
获得下面执行结果,pg_blocking_pids 为正在执行的线程;
如果段多次执行发现某个线程一直存在,并未释放,则执行 下面脚本,将线程ID放入括号中,进行释放
select pg_cancel_backend(1111);
2、等待线程未执行
如果上面方法无法处理,则执行下面脚本
datname 值为用户名称,替换成自己的用户名即可
SELECT * FROM pg_stat_activity WHERE datname='root' and wait_event_type='Lock' ORDER BY backend_start;
获得下面执行结果,pid 为正在等待的线程,结果一般会存在多条;
获取第一条结果的pid,则执行下面脚本,将pid放入括号中,进行释放
select pg_cancel_backend(1111);
以上为postgres 数据库死锁的问题定位,如果还存在其它场景,欢迎评论区补充