网站首页 > 教程文章 正文
在遇到迟迟无法执行完成的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)分析慢节点原因并考虑是否重启该节点
在使用GBase南大通用产品过程中,若有任何问题,欢迎前往GBase南大通用官网提问~
——GBASE南大通用GBase 8a
猜你喜欢
- 2025-07-03 MySQL面试题(二)(mysql 面试题)
- 2025-07-03 MySQL 教程的天花板--入门到高级(mysql入门视频教程)
- 2025-07-03 MySQL--多表连接查询(mysql多表连接查询怎么学啊)
- 2025-07-03 一分钟教你学会SQL查询执行流程(sql查询操作步骤)
- 2025-07-03 MySQL实战:小白能轻松上手的多表关联查询性能优化实战
- 2025-07-03 面试官灵魂拷问:为什么 SQL 语句不要过多的 join?
- 2025-07-03 2025软考架构师数据库章节该如何学习?
- 2025-07-03 MySQL数据库 - 语句执行顺序(mysql语句执行原理)
- 2025-07-03 Hive 必会 SQL 语法 explode 和 lateral view
- 2025-07-03 2万字,深度解析SQL性能优化,值得收藏
- 最近发表
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- mybatis plus page (35)
- vue @scroll (38)
- 堆栈区别 (33)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)
- redis aof rdb 区别 (33)
- 302跳转 (33)
- http method (35)
- js array splice (33)