GBASE南大通用-GBase 8a排查慢SQL

在遇到迟迟无法执行完成的SQL时,通常有以下几种常见情况:

1. 锁堵塞

1)先通过show processlist命令,查看SQL的状态,观察其是否为"checking permission",如果是,则大概率是锁堵塞。如果不是,则不是锁堵塞。

2)当是时,通过gcadmin showlock命令,查看当前集群的锁信息。

a. 记录processlist中,该SQL的会话ID

b.在showlock信息中,通过会话ID,确认该SQL在等待哪个锁。比如下图,就查出了ID=269的SQL在等待哪个锁

c.在showlock信息中,搜索该锁在被哪条SQL持有。

d.回到processlist信息,确认ID=342的SQL的执行情况。判断其是否在正常执行,是否可以kill掉以释放锁。

2. 笛卡尔积

1)扫描各节点的磁盘情况,观察是否存在磁盘突然增长的情况。因为笛卡尔积SQL会导致出现大量的临时数据占用磁盘。

a.在各节点上du -sh ../gnode/tmpdata

b.若出现某节点空间明显高于其他节点的情况,则为异常

2)前往异常节点的tmpdata目录下,查看文件名称,文件最多的文件名称开头即为会话ID

3)gncli登录该节点,通过会话ID,关联到其在gcluster层的会话id。在GNode层SQL语句的hint中会带有其在gcluster层的会话id

4)登录gcluster节点,根据2806155查看SQL并分析SQL。

3. 慢节点堵塞

1)通过gcluster层的会话ID,前往各GNode节点,查看该SQL在各GNode层的执行情况。

2)若该SQL,目前只有一个节点在执行,则可能因为木桶理论导致SQL被堵塞

3)观察该GNode节点的SQL情况,判断其积压的SQL数量是不是明显高于其他节点

4)观察该节点的资源历史占用情况

5)分析慢节点原因并考虑是否重启该节点

相关推荐
Rubin智造社10 分钟前
Claude Code开发者大会系列2|“饮鸩止渴”还是“即刻解药”?Anthropic与SpaceX的联姻内幕
大数据·数据库·人工智能·开发者大会·anthropic·claude code
噢,我明白了12 分钟前
表单的完整 CRUD 练习【极简个人记账本】(含前端后端链接mySQL)
java·前端·数据库·mysql
2301_809204702 小时前
bootstrap怎么实现鼠标悬停切换图片预览功能
jvm·数据库·python
小短腿的代码世界7 小时前
Qt 股票订单撮合引擎:高频交易系统的核心心脏
开发语言·数据库·qt·系统架构·交互
JosieBook7 小时前
【数据库】时序数据库选型指南:从数据模型到大模型智能分析
数据库·时序数据库
小猿姐8 小时前
Clickhouse Kubernetes Operator 实测:哪种方案更适合生产?
运维·数据库·kubernetes
2501_921939268 小时前
MHA高可用
数据库·mysql
_Evan_Yao9 小时前
MySQL 基础:SELECT、WHERE、JOIN 的第一次使用
数据库·mysql
weixin_444012939 小时前
c++如何将std--vector直接DUMP到二进制文件_指针地址直写【附代码】
jvm·数据库·python
woxihuan12345610 小时前
Go语言中--=运算符详解:位右移赋值操作的原理与应用
jvm·数据库·python