GaussDB 数据库架构师(八) 等待事件概述-1

1、等待事件概述

等待事件:指当数据库会话(session)因资源竞争依赖无法继续执行时,进入"等待"状态,此时产生的性能事件即等待事件。

2、等待事件本质

性能瓶颈的信号灯,反映CPU,I/O、锁、网络等关键资源的阻塞情况。当系统存在阻塞时,优先通地等待事件分析瓶颈点。

3、 常见等待事件

常见等待事情如下表:

|-----------------------------------------------|------------------------------------------------------------------------------|
| 等待事件 | 解释 |
| STATUS(WAIT CMD) | 等待应用侧发数据,表示此内核session正在等待用户发送数据 |
| STATUS(none) | 正在执行过程中,未在某个events产生较多耗时,此状态下内核侧从events来看无明显瓶颈 |
| IO_EVENT(LOGCTRL_SLEEP) | 数据库发生限流,为了保障数据库的RTO,数据库本身具备流控的能力(受recovery_time_target控制);在压力测试的时候,性能压制较为明显。 |
| STATUS(wait node) | 表示当前Query正在等待其他结点返回,通常如果多数查询在等待某个节点。 |
| STATUS(wait wal sync) | 等待wal日志同步,通常表示事务提交等待备机日志下盘。 |
| STATUS(flush data) | 网络数据发送 |
| STATUS(Sort/Sort-fetch tuple/Sort-write file) | 分别表示正在执行sort算子,获取sort元组,sort下盘操作,其它算子Material/HashJoin/HashAgg等类似 |
| IO_EVENT(DataFileRead/ DataFileWrite) | IO异常使用 |
| LOCK_EVENT(tuple/transactionid) | 通常大量出现这两个等件事件,业务极大可能出来并发更新,出现整体业务阻塞 |

详细的其它等待事件看:

PG_THREAD_WAIT_STATUS_系统视图_系统表和系统视图_开发指南(集中式_V2.0-3.x)_云数据库 GaussDB-华为云

4、查询等待事件视图:

  • dbe_perf.wait_events、dbe_perf.global_wait_events
  • statement_history表detail字段
  • pgxc_thread_wait_status(实时-分布式)、pg_thread_wait_status(实时-集中式)、
  • gs_asp、dbe_perf.local_active_session(历史)

5、等待事件优化流程

6、批注

等待事件是我们分析性能问题的重要手段,在实际生产环境性能调优非常的有用。

相关推荐
xmjd msup5 小时前
mysql的分区表
数据库·mysql
Lyyaoo.5 小时前
【JAVA Spring面经】Spring 事务失效情况
java·数据库·spring
MeAT ITEM5 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
dovens5 小时前
PostgreSQL 中进行数据导入和导出
大数据·数据库·postgresql
IOT.FIVE.NO.15 小时前
claude code desktop cowork报错解决和记录Workspace..The isolated Linux environment ...
linux·服务器·数据库
Rick19935 小时前
mysql 慢查询怎么快速定位
android·数据库·mysql
科技小花12 小时前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
X566113 小时前
如何在 Laravel 中正确保存嵌套动态表单数据(主服务与子服务)
jvm·数据库·python
虹科网络安全14 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_7717172114 小时前
解决mysql报错:1406, Data too long for column
android·数据库·mysql