0

0

SQL pg_stat_activity 的 wait_event_type 与阻塞诊断模板

冰川箭仙

冰川箭仙

发布时间:2026-02-21 19:03:11

|

312人浏览过

|

来源于php中文网

原创

wait_event_type显示的是进程当前等待类型(如client、io),并非阻塞源;定位阻塞需结合pg_blocking_pids()或pg_locks中granted=false等字段分析。

sql pg_stat_activity 的 wait_event_type 与阻塞诊断模板

wait_event_type 时为什么总看到 ClientIO 却没发现锁?

因为 wait_event_type 描述的是「当前正在等什么」,不是「谁在阻塞你」。它只反映 PostgreSQL 后端进程的即时等待状态,和锁链无关——比如 Client 表示在等客户端发下一条命令,IO 可能只是刷 WAL 或读数据页,这些都不是阻塞源。

真正要定位阻塞,得结合 pg_blocking_pids(pid) 或自连 pg_stat_activityblocking_pid 字段(14+ 版本);老版本只能靠 pg_locks 关联 granted = falsetransactionid 倒推。

  • wait_event_type 是“症状”,不是“病因”;别把它当锁表依据
  • 常见误判:Lock 类型确实可疑,但 Lock + wait_event = 'relation' 才大概率是 DDL 阻塞,而 Lock + 'transactionid' 多是长事务未提交
  • 如果 wait_event_typeClient,先看 state = 'idle in transaction' —— 这才是隐藏杀手,它不等资源,但会一直占着锁

pg_stat_activity 搭配 pg_locks 写阻塞诊断 SQL 时字段怎么对齐?

核心是把 pg_stat_activity.pidpg_locks.pid 关联,但要注意:10+ 版本 pg_locks.pid 是持有锁或等待锁的 backend pid,而 pg_stat_activitypid 是唯一标识,可直接 join;9.6 及更早需用 pg_locks.virtualxidtransactionid 间接关联,逻辑更绕。

一个稳妥的诊断模板(PostgreSQL 12+):

Cleanup.pictures
Cleanup.pictures

智能移除图片中的物体、文本、污迹、人物或任何不想要的东西

下载
SELECT blocked.pid AS blocked_pid,
       blocked.query AS blocked_query,
       blocking.pid AS blocking_pid,
       blocking.query AS blocking_query,
       blocked.wait_event_type,
       blocked.wait_event
FROM pg_stat_activity blocked
JOIN pg_stat_activity blocking ON blocking.pid = ANY(pg_blocking_pids(blocked.pid))
WHERE blocked.state = 'active' AND blocked.wait_event IS NOT NULL;
  • 必须加 blocked.state = 'active',否则会拉出一堆 idle 进程干扰判断
  • pg_blocking_pids() 返回数组,要用 = ANY(...),不能用 =
  • 如果查不到 blocking 进程,可能是它已退出但事务未结束(如 crash 后未清理),此时要去 pg_locksgranted = false 的行,并找对应 virtualxid 的最早持有者

wait_event_type = 'Lock'wait_event 是空值,怎么回事?

这是 PostgreSQL 14 引入的行为:当等待类型为 Lock,但具体锁对象尚未确定(比如正处在锁升级、或锁管理器内部路径中),wait_event 就留空。它不代表没锁,反而说明锁竞争发生在更底层,比如 tuple 级锁升级为 page 锁时的中间态。

  • 遇到空 wait_eventwait_event_type = 'Lock',优先检查是否有大量 UPDATE/DELETE 在同一张小表上高频执行——容易触发锁升级争用
  • 对比 pg_locks.locktype:如果对应行的 locktype = 'tuple'mode = 'RowExclusiveLock',但 granted = false,基本可断定是热点行锁冲突
  • 这种空值不会出现在 pg_stat_activity 的旧版本(13 及以前),所以升级后突然看到空值,别慌,是行为变更,不是数据损坏

为什么在 RDS 或 Aurora 上查不到真实的 blocking_pid

云厂商常屏蔽或重写 pg_stat_activity 中的敏感字段。例如 AWS RDS 默认关闭 rds.force_ssl 以外的某些权限,且 blocking_pid 列在多数 RDS 版本里始终为 NULL;Aurora 更进一步,用自研锁管理器,pg_blocking_pids() 返回空数组是常态。

  • 替代方案:用 SELECT * FROM pg_locks WHERE NOT granted ORDER BY pid;,再人工比对 databaserelationtransactionid 字段,找「有锁没被授」的源头
  • RDS 上可以开启 log_lock_waits = on,配合 deadlock_timeout 抓日志,虽然滞后但信息更全
  • 别依赖 pg_stat_activity 的单次快照——云环境锁可能秒级释放,建议用 pg_stat_activity + pg_locks 联合视图每 5 秒采样一次,存到临时表再分析

真实阻塞链往往跨多个事务、涉及隐式锁升级和云平台抽象层,光盯 wait_event_type 容易漏掉中间环节。尤其当 wait_event 为空、或 blocking_pid 不可见时,得切到 pg_locks 底层字段一层层剥。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1006

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

335

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

379

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1782

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

376

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1332

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

436

2024.04.29

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

916

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号