当前位置: 首页 > news >正文

记录一次长时间未提交事务造成的慢SQL

目录

问题描述

问题分析

1、了解前后信息

2、分析执行计划

3、分析生产环境系统负载

4、分析数据库性能

5、初步锁定根因为长时间未提交事务导致

6、最终根因定位

7、原理分析


问题描述:

开发反馈执行某条select语句的时候,生产环境和测试环境耗时相差非常大,生产耗时要18S,测试环境耗时不到1秒钟。

问题分析:

1、了解前后信息

a、该SQL是近期新上的

b、生产执行耗时要18S,测试环境耗时不到1秒钟

c、该SQL属于业务人员点击页面发起的查询

d、普通select语句

2、分析执行计划

比较了生产和测试环境的执行计划,执行计划完全相同,比较数据量也相差不大,因此排除执行计划不同导致的耗时差异。

3、分析生产环境系统负载

检查生产环境io、cpu、内存负载情况,系统负载不高,未发现瓶颈。

4、分析数据库性能

a、计算缓冲池命中率,可以达到99.99%,说明数据库内存配置合理

b、检查数据库会话信息,活跃连接数量、连接数使用率不高,未发现瓶颈

c、检查数据库异常会话,依次检查数据库是否有锁等待、长时间未提交事务,发现数据库有一条insert into select 的SQL语句已经执行超过半个月还没有提交,该insert语句中的select子查询为多表关联,其中一张表与耗时慢的SQL涉及的表相同,故怀疑耗时慢的select语句是受到长时间未提交事务影响。

d、查看该慢SQL在主库和从库的执行计划、耗时,发现主从执行计划相同,主库执行耗时18S,从库执行耗时11S,从库执行明显比主库快。

5、初步锁定根因为长时间未提交事务导致

a、手动将长时间未提交事务杀掉

b、再次查看该慢SQL在主库的耗时,发现耗时已经降到11S,和从库一致。至此,已经解决了主从执行耗时不一致的问题。还剩下一个问题,就是生产和测试执行耗时不同。

c、继续分析慢SQL,该select语句用到了group by和order by,并且生产和测试都用到了file sort,去掉order by,发现测试用于排序的行记录数比生产少很多,测试返回给排序的行记录数为几百条,而生产上返回给排序的行记录是几百万行,故生产耗时比测试多也是意料之中。毕竟,测试数据是做过脱敏处理,并且测试和生成数据也有区别。

6、最终根因定位

即长时间未提交事务导致主库对应的select语句性能下降,解决方案为杀掉长时间未提交的事务。

7、原理分析

给大家留个思考,我们下次再展开讨论,大家可以在评论区发表自己的看法。

http://www.jsqmd.com/news/674923/

相关文章:

  • Python的__getattribute__方法实现属性访问重写与元类协作在框架设计
  • 自学渗透测试第20天(防火墙基础与规则配置)
  • 别再只用远程桌面了!用frp给家里电脑开个‘后门’,映射硬盘、Web服务甚至游戏服务器
  • CSS如何高效命名样式类_掌握BEM规范提升语义化程度
  • 像素剧本圣殿实战教程:Qwen2.5-14B-Instruct生成适配TikTok/YouTube Shorts的竖屏剧本
  • 2026年口碑好的厂区专用消防车/山东消防车/消防车/四轮消防车长期合作厂家推荐 - 行业平台推荐
  • xattr实战:从POSIX API到内核实现的深度解析
  • 【Java Loom安全转型权威指南】:20年架构师亲授响应式迁移中97%团队忽略的3大线程安全陷阱
  • 华硕枪神8/8Plus 超竞版 G634J G614J G814J G814J 原厂Win11 22H2系统分享下载-宇程系统站
  • 幻境·流金多场景落地:支持教育课件配图、科研论文插图、展览海报
  • 蓝桥杯:大学生技术成长的“试金石”与“加速器”
  • [GXYCTF2019]禁止套娃
  • PyTorch实战解析:nn.SmoothL1Loss在目标检测中的鲁棒回归应用
  • EXP-00106: 数据库链接口令无效
  • 告别卡顿!优化Windows 11 Miracast投屏体验,让小米手机投屏更流畅
  • Real-Anime-Z开源实践:基于Z-Image Turbo的LoRA训练数据集分析
  • 每日热门skill:OpenClaw 268k下载量的“记忆外挂“:self-improving-agent深度解析
  • 如何优雅地使用c语言编写爬虫
  • 51单片机型号数字暗藏玄机?STC89C51、C52、C54命名规则与存储空间全解析
  • nli-MiniLM2-L6-H768生产环境:与Elasticsearch结合实现语义检索重排序
  • egergergeeert惊艳效果:11张高细节服装纹理+发丝表现的插画作品
  • 拯救者工具箱:让你的联想笔记本性能翻倍的开源神器
  • 2026年靠谱的本溪旅游徒步游/本溪旅游亲子游亲子游排行榜 - 品牌宣传支持者
  • Phi-3.5-mini-instruct架构对比:与Llama3-8B在注意力机制与长文本处理差异
  • 在Replit上构建你的首个全栈应用:从零到部署的免费实践
  • 【二层和三层的区别】dis ospf peer和dis lldp nei int g x/x/x命令的区别?
  • 框架原理解析
  • 程序员鱼皮AI智能体项目学习体验分享|给Java学习者的真实参考
  • GraalVM Native Image内存优化实战手册(金融级低延迟场景验证版)
  • 手把手教你改造RuoYi-Vue,让它同时连接MySQL和TDengine 3.0