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

记录一次长时间未提交事务造成的慢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、原理分析给大家留个思考我们下次再展开讨论大家可以在评论区发表自己的看法。

相关文章:

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

目录 问题描述 问题分析 1、了解前后信息 2、分析执行计划 3、分析生产环境系统负载 4、分析数据库性能 5、初步锁定根因为长时间未提交事务导致 6、最终根因定位 7、原理分析 问题描述: 开发反馈执行某条select语句的时候,生产环境和测试环境耗时相差非…...

如何优雅地使用c语言编写爬虫

前言 大家在平时或多或少地都会有编写网络爬虫的需求。一般来说,编写爬虫的首选自然非python莫属,除此之外,java等语言也是不错的选择。选择上述语言的原因不仅仅在于它们均有非常不错的网络请求库和字符串处理库,还在于基于上述语…...

幻境·流金多场景落地:支持教育课件配图、科研论文插图、展览海报

幻境流金多场景落地:支持教育课件配图、科研论文插图、展览海报 1. 引言:让专业视觉创作变得简单高效 在日常工作和学习中,我们经常需要制作各种视觉材料——老师需要为课件配图,研究人员需要为论文制作插图,策展人员…...

自学渗透测试第20天(防火墙基础与规则配置)

7.3 防火墙基础与规则配置(第20天)核心目标理解防火墙原理:掌握包过滤、状态检测、应用层代理等防火墙工作原理,理解iptables/netfilter架构。掌握iptables配置:熟练使用iptables命令配置防火墙规则,实现访…...

Beyond Compare 5密钥生成器:简单高效的文件对比工具激活方案

Beyond Compare 5密钥生成器:简单高效的文件对比工具激活方案 【免费下载链接】BCompare_Keygen Keygen for BCompare 5 项目地址: https://gitcode.com/gh_mirrors/bc/BCompare_Keygen 还在为Beyond Compare 5的30天评估期到期而烦恼吗?BCompare…...

5分钟快速上手:QMCDecode音频格式转换完整指南

5分钟快速上手:QMCDecode音频格式转换完整指南 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac,qmc0,qmc3转mp3, mflac,mflac0等转flac),仅支持macOS,可自动识别到QQ音乐下载目录,默认转换结果…...

【限时解密】Loom响应式项目CI/CD流水线重构方案(GitHub Actions + JUnit 5.12+ Loom-aware Profiling插件)

第一章:Java 项目 Loom 响应式编程转型指南 2026 最新趋势 Java 平台在 2026 年已全面拥抱 Project Loom 的虚拟线程(Virtual Threads)与结构化并发(Structured Concurrency),并与响应式编程范式深度协同。…...

规划失败怎么办:回退、改写与再规划策略

规划失败怎么办:回退、改写与再规划全链路策略 副标题:从软件工程、AI Agent到企业战略的通用可落地框架,附代码实现与实战案例 第一部分:引言与基础 1.1 摘要/引言 你有没有遇到过这些崩溃时刻: 花了3个月做的技术规划,上线第一天就出现核心链路故障,半年的投入几乎…...

MFC 去掉CSV文件(指定文件路径)末尾的换行符

#include <fstream> #include <string>//去掉CSV文件&#xff08;指定文件路径&#xff09;末尾的换行符 BOOL RemoveTrailingNewlineFromCSV2(const CString& strFilePath) {if (strFilePath.IsEmpty())return FALSE;// 以二进制模式打开文件std::fstream fil…...

RMBase数据库数据整理

我下载的RMBase BED文件&#xff0c;打开第一行是这样的&#xff1a;chr1 14414 14415 m6A_site_1 0 - m6A 2 GSE102493 GSM2739535,GSM2991403 29507755 HeLa m6A-seq ENSG00000227232.5 ENST00000488147.1 WASH7P unprocessed_pseudogene exon-11 GGCACACCAATCAATAAAGAACTGAG…...

GraalVM Native Image内存优化实战手册(金融级低延迟场景验证版)

第一章&#xff1a;GraalVM Native Image内存优化实战手册&#xff08;金融级低延迟场景验证版&#xff09;在高频交易与实时风控等金融级低延迟系统中&#xff0c;GraalVM Native Image 的启动延迟与运行时内存开销直接影响端到端 P99 延迟稳定性。本章基于某头部券商订单网关…...

3步实现CATIA几何特征智能识别:工业软件二次开发提升设计效率指南

3步实现CATIA几何特征智能识别&#xff1a;工业软件二次开发提升设计效率指南 【免费下载链接】pycatia python module for CATIA V5 automation 项目地址: https://gitcode.com/gh_mirrors/py/pycatia 在现代CAD设计流程中&#xff0c;工程师经常需要处理大量重复的几何…...

别再死记硬背了!用PyTorch亲手画一画CNN的特征图,秒懂它在‘看’什么

用PyTorch可视化CNN特征图&#xff1a;揭开神经网络的神秘面纱 当你第一次听说卷积神经网络&#xff08;CNN&#xff09;能识别猫狗时&#xff0c;是否也好奇过它究竟"看到"了什么&#xff1f;那些抽象的数字矩阵背后&#xff0c;隐藏着怎样的视觉逻辑&#xff1f;今…...

ITK-SNAP医学图像分割架构深度解析与性能优化实战指南

ITK-SNAP医学图像分割架构深度解析与性能优化实战指南 【免费下载链接】itksnap ITK-SNAP medical image segmentation tool 项目地址: https://gitcode.com/gh_mirrors/it/itksnap ITK-SNAP作为一款专业的医学图像分割工具&#xff0c;其核心价值不仅在于直观的用户界面…...

别再被短读长困扰了!手把手教你用PacBio Sequel平台搞定10Kb+长读长测序

突破基因组拼接瓶颈&#xff1a;PacBio Sequel长读长测序实战指南 当你在深夜盯着电脑屏幕&#xff0c;面对那些无法闭合的基因组缺口时&#xff0c;是否曾想过——或许问题并不出在你的分析技巧&#xff0c;而是数据本身存在先天不足&#xff1f;短读长测序技术虽然成熟可靠&a…...

JS逆向实战:Hook技术对抗与绕过无限Debugger的防御策略

1. 无限Debugger的常见类型与原理剖析 第一次遇到无限Debugger时&#xff0c;我正试图抓取某电商网站的价格数据。刚打开开发者工具&#xff0c;页面就像卡死的音乐盒一样不断弹出调试窗口&#xff0c;鼠标根本来不及点"继续执行"。这种防御机制看似无解&#xff0c;…...

无人机送货时如何‘看’得更远?聊聊MPC里的预测时域K和采样时间dt怎么调

无人机送货时如何优化MPC的视野&#xff1a;预测时域K与采样时间dt的工程调参艺术 当无人机在复杂城市环境中执行送货任务时&#xff0c;控制器需要像老司机一样具备"预判能力"——不仅要处理当前的飞行状态&#xff0c;还要提前规划未来几秒甚至十几秒的轨迹。这正是…...

电力老师傅带你读懂IEC 60870-5-101规约:从帧格式到主站子站对话全解析

电力老师傅手把手教你玩转IEC 60870-5-101规约 记得刚入行那会儿&#xff0c;第一次看到IEC 60870-5-101规约文档&#xff0c;整个人都是懵的——满眼的十六进制代码、控制位定义、报文格式&#xff0c;活像一本天书。直到跟着师傅在变电站蹲了三个月&#xff0c;才慢慢摸清门道…...

RMBG-2.0效果对比:与传统工具PK,毛发玻璃杯处理更精准

RMBG-2.0效果对比&#xff1a;与传统工具PK&#xff0c;毛发玻璃杯处理更精准 1. 为什么传统抠图工具总让你抓狂&#xff1f; 想象一下这些场景&#xff1a; 你正在为电商产品图去除背景&#xff0c;但玻璃杯的透明部分总是被误判为背景拍摄的宠物照片需要抠图&#xff0c;但…...

在Replit上构建你的首个全栈应用:从零到部署的免费实践

1. 为什么选择Replit开发全栈应用&#xff1f; 第一次听说Replit时&#xff0c;我正为学生的课程设计发愁——他们需要完成一个包含前后端的全栈项目&#xff0c;但很多人的笔记本电脑跑不动开发环境。直到发现这个神奇的云端IDE&#xff0c;所有问题迎刃而解。Replit最吸引我的…...

51单片机型号数字暗藏玄机?STC89C51、C52、C54命名规则与存储空间全解析

51单片机型号密码&#xff1a;从STC89C52数字后缀破解存储空间玄机 第一次接触51单片机时&#xff0c;你是否也被各种型号后缀搞得一头雾水&#xff1f;STC89C51、C52、C54这些看似随机的数字组合&#xff0c;其实暗藏着一套精妙的行业密码。今天我们就来当一回"芯片侦探&…...

HY-Motion-1.0效果展示:真实感3D角色动画生成案例集

HY-Motion-1.0效果展示&#xff1a;真实感3D角色动画生成案例集 1. 引言&#xff1a;重新定义3D动画制作方式 想象一下&#xff0c;你只需要用简单的文字描述&#xff0c;就能生成专业级的3D角色动画。这不是科幻电影中的场景&#xff0c;而是HY-Motion 1.0带来的现实突破。 …...

手把手教你改造RuoYi-Vue,让它同时连接MySQL和TDengine 3.0

企业级物联网监控系统改造实战&#xff1a;RuoYi-Vue整合TDengine 3.0全指南 当传统关系型数据库遇上物联网海量时序数据&#xff0c;技术架构该如何优雅进化&#xff1f;本文将带您深入一个真实的企业级改造案例——基于RuoYi-Vue框架的监控系统如何无缝接入TDengine时序数据库…...

egergergeeert惊艳效果:11张高细节服装纹理+发丝表现的插画作品

egergergeeert惊艳效果&#xff1a;11张高细节服装纹理发丝表现的插画作品 1. 作品展示&#xff1a;高精度服装与发丝细节 egergergeeert文生图镜像在角色插画创作中展现出惊人的细节表现力&#xff0c;特别是在服装纹理和发丝处理方面。以下是11张具有代表性的高质量作品展示…...

告别卡顿!优化Windows 11 Miracast投屏体验,让小米手机投屏更流畅

告别卡顿&#xff01;优化Windows 11 Miracast投屏体验&#xff0c;让小米手机投屏更流畅 无线投屏技术早已不是新鲜事物&#xff0c;但真正流畅无延迟的体验却依然难得。作为一名长期使用小米手机和Windows 11系统的技术爱好者&#xff0c;我深刻理解那种看着投屏画面卡成PPT的…...

保姆级教程!4个mp4转mp3工具盘点,手机电脑都能用,速码住

在短视频、自媒体、音频剪辑越来越流行的今天&#xff0c;提取视频中的背景音乐已经成了刚需。比如追剧时听到一首超好听的OST&#xff0c;想做成手机铃声&#xff1b;旅行vlog里的BGM想单独拿出来用&#xff1b;甚至教学视频里的关键音频需要提取出来。这时候MP4转MP3就派上用…...

告别黑盒:手把手教你用AssetStudio查看并导出Unity打包后的游戏UI与图片素材

告别黑盒&#xff1a;手把手教你用AssetStudio查看并导出Unity打包后的游戏UI与图片素材 当你被一款游戏的精美UI设计所吸引时&#xff0c;是否好奇过这些视觉元素是如何实现的&#xff1f;作为UI设计师或独立开发者&#xff0c;学习逆向分析成熟作品的资源结构&#xff0c;是提…...

如何用 storage 估算机制检测本地剩余可用存储容量大小

StorageManager.estimate() 方法异步估算当前 origin 的存储使用量&#xff08;usage&#xff09;和可用配额&#xff08;quota&#xff09;&#xff0c;返回 Promise&#xff0c;需安全上下文&#xff0c;结果为启发式估算而非精确值&#xff0c;适用于容量预警与缓存优化。现…...

用Python+代理IP池模拟真实用户,手把手教你实现抖音直播间自动互动脚本

Python自动化直播间互动技术解析 在当今数字营销领域&#xff0c;直播平台已成为品牌与用户互动的重要渠道。对于开发者而言&#xff0c;理解如何通过技术手段实现自动化互动不仅具有学习价值&#xff0c;也能为数据分析提供支持。本文将深入探讨基于Python的直播间自动化技术实…...

C语言中digit的含义解析

1、 null 2、 数字的含义。 3、 C语言是一种面向过程的通用编程语言&#xff0c;具有良好的抽象能力&#xff0c;常用于系统底层开发。它能够简洁地编译并直接操作低级内存&#xff0c;生成高效的机器代码&#xff0c;且无需依赖运行环境即可执行&#xff0c;具备极高的运行效率…...