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)分析慢节点原因并考虑是否重启该节点

相关推荐
敲代码敲到头发茂密24 分钟前
基于 LangChain 实现数据库问答机器人
数据库·人工智能·语言模型·langchain·机器人
一入程序无退路1 小时前
c语言传参数路径太长,导致无法获取参数
linux·c语言·数据库
陌夏微秋2 小时前
STM32单片机芯片与内部47 STM32 CAN内部架构 介绍
数据库·stm32·单片机·嵌入式硬件·架构·信息与通信
计算机学无涯2 小时前
Spring事务回滚
数据库·sql·spring
web130933203983 小时前
flume对kafka中数据的导入导出、datax对mysql数据库数据的抽取
数据库·kafka·flume
张声录13 小时前
【ETCD】【实操篇(二十)】浅谈etcd集群管理的艺术:从两阶段配置到灾难恢复的设计原则
数据库·etcd
qq_254674413 小时前
数据仓库和数据湖 数据仓库和数据库
数据库·数据仓库
--FGC--3 小时前
【第2篇】 Python与数据库基础
数据库·python·oracle
Y.O.U..4 小时前
Mysq学习-Mysql查询(4)
数据库·学习·mysql
安晴晚风4 小时前
从0开始在linux服务器上部署SpringBoot和Vue
linux·运维·前端·数据库·后端·运维开发