postgres死锁问题定位

在项目上遇到了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 数据库死锁的问题定位,如果还存在其它场景,欢迎评论区补充

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值