mysql怎么查询慢的sql语句
时间:2022-05-28 [网络编程]作者:fabuyuan 浏览:6 次
方法:1、若未开启慢查询,用“set global slow_query_log='ON';”开启慢;2、用“set global slow_query_log_file=路径”设置慢查询文件保存位置;3、用“subl 路径”查询文件即可。
本教程操作环境:centos 7系统、mysql8.0.22版本、Dell G3电脑。
mysql怎么查询慢的sql语句
Mysql中 查询慢的 Sql语句的记录查找
慢查询日志 slow_query_log,是用来记录查询比较慢的sql语句,通过查询日志来查找哪条sql语句比较慢,这样可以对比较慢的sql可以进行优化。
登陆mysql数据库:
1、查看一下当前的慢查询是否开启,若未开启则开启
以及慢查询所规定的时间:
show variables like 'slow_query_log'; show variableslike 'long_query_time';
如果你的查询后的结果是OFF 状态的话,就需要通过相关设置将其修改为ON状态:
set global slow_query_log='ON';
将慢查询追踪的时间设置为1s:
这里你在设置之后,这个世界是不会立即变成1s的,需要在数据库重启后才生效:
2、设置慢查询日志文件保存的位置:
set global slow_query_log_file='/var/lib/mysql/test_1116.log';
3、 查看以下配置后的文件:
sudo subl /var/lib/mysql/test_1116.log
扩展知识:
MySQL数据库慢查询问题排查方法
最近碰到了几次数据库响应变慢的问题,整理了一下处理的流程和分析思路,执行脚本。希望对其他人有帮助。
MySQL慢查询表现
明显感觉到大部分的应用功能都变慢,但也不是完全不能工作,等待比较长的时间还是有响应的。但是整个系统看起来就非常的卡。
查询慢查询数量
一般来说一个正常运行的MySQL服务器,每分钟的慢查询在个位数是正常的,偶尔飙升到两位数也不是不能接受,接近100系统可能就有问题了,但是还能勉强用。这几次出问题慢查询的数量已经到了1000多。
慢查询的数量保存在mysql库里面的slow_log表。
SELECT * FROM `slow_log` where start_time > '2019/05/19 00:00:00';
这样就能查出一天以来的慢查询了。
查看当前进行的查询状态
大家应该都比较常用show processlist来查看当前系统中正在执行的查询,其实这些数据也保存在information_schema库里面的processlist表,因此如果要做条件查询,直接查询这张表更方便。
比如查看当前所有的process
select * from information_schema.processlist
查看当前正在进行的查询并按照已经执行时间倒排
select * from information_schema.processlist where info is not null order by time desc
正常运行的数据库,因为一条查询的执行速度很快,被我们的select抓到的info不是null的查询数量会很少。我们这样负荷很大的库一般也就只能查到几条。如果一次能查到info非空的查询有几十条,那么也可以认为系统出问题了。
系统问题和定位
当我们察觉到系统变慢之后,马上用慢查询和查看processlist的方式做了检查,结果发现每分钟慢查询数量飙升到1000多,同时淤积了大量的查询在执行中。
因为当务之急是尽快恢复系统的正常运行,因此影响最直接的做法是在processlist的查询结果中,查看有多少哪些查询处于lock状态,或者已经执行了很长时间,把这些process用kill指令干掉。通过不停的杀死这些可能会引发系统阻塞的process,最终能够暂时让系统逐步恢复到正常状态,当然这只是权宜之计。
此外,最重要的当然是分析到底是哪些查询为什么会引发系统阻塞,我们还是使用慢查询来做分析。
慢查询表查询结果里面有几个比较重要的指标:
start_time 开始时间,要通过这个参数,配合系统出问题的时间,定位哪些查询是罪魁祸首。
query_time 查询时间
rows_sent 和 rows_examined发送的结果数以及查询扫过的行数,这两个值特别重要,特别是 rows_examined。基本上就能告诉我们,哪个查询是需要注意的“大”查询。
实际操作中,我们也是把有大量rows_examined的查询一个个拿出来分析,添加索引,修改查询语句的编写,来彻底的解决问题。
处理结果和反思
经过对所有慢查询的检查和整改,目前MySQL每分钟慢查询数徘徊在1~2之间,CPU的负荷也非常低。问题算是基本得到了解决。
反思一下问题出现的原因,有几个地方需要注意:
1,数据库出问题往往不是上线即引发问题,而是有一个累积的过程,不断累加的糟糕的查询语句会逐步增加系统负载,最后压倒骆驼的最后一根稻草往往看上去莫名其妙
2,最后的一根稻草甚至有可能根本不存在,不是一次发版或者是功能上线,而是随着用户使用量上升,数据量的累积而爆发
3,既然问题的出现是累积的过程,就需要在每次代码发版之前做好review
4,索引的添加很重要
5,慢查询的监控也需要纳入到Zabbix的监控范围
推荐学习:mysql视频教程
以上就是mysql怎么查询慢的sql语句的详细内容,更多请关注站长家园其它相关文章!
本文标签: mysql
转载请注明来源:mysql怎么查询慢的sql语句
本文永久链接地址:https://www.adminjie.com/post/12902.html
免责声明:
本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
附:
二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!
版权声明:
一、本站致力于为软件爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的部分源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、我站提供用户下载的所有内容均转自互联网。如有内容侵犯您的版权或其他利益的,若有侵犯你的权益请:提交版权证明文件到邮箱 2225329873#qq.com(#换为@) 站长会进行审查之后,情况属实的会在三个工作日内为您删除。
更多精彩内容
- VUE中V-IF条件判断改变元素的样式操作
- Discuz如何解决安装时报错run_sql_error
- 低版本VS项目在VS2019无法正常编译的问题
- PHP+Redis链表解决高并发下商品超卖问题(实现原理及步骤)
- Oracle数据库的实例/表空间/用户/表之间关系简单讲解
- RSA2是啥?PHP-RSA2签名验证怎么实现?
- app是什么应用程序的简称
- 华为dubal20是什么型号
- 小程序大小超限除了分包还能怎么做?如何避免和解决大小限制?
- 电脑显示信号线无连接是什么意思
- html5中onclick是什么意思
- ana an00华为是什么型号
- 超清视效是什么意思
- html中value是什么意思
- vivov1818a是什么手机型号

- 最新文章
-
-
PHP是一种垂死的语言吗?
似乎这个问题每年都会被问到,因为出于某种原因,人们对PHP的看法是它是业余爱好者使用的一种语言,或者是一种垂死的语言——一种正在消亡的编程语言。在我们了解“...
-
JavaScript弱映射与弱集合知识详解
本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了关于弱映射与弱集合的相关问题,下面一起来看一下,希望对大家有帮助。【相关推荐:javasc...
-
mysql怎么查询临时表
本教程操作环境:windows7系统、mysql8版本、DellG3电脑。mysql临时表在MySQL中,临时表是一种特殊类型的表,允许您存储临时结果集,您可...
-
Java中的set集合如何理解
本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于set集合的相关问题,set集合的特点是无序、不重复并且没有索引,下面一起来看一下,希望对大家有帮...
-
mysql存储过程中的循环语句有哪些
mysql存储过程中的循环语句有三种:1、WHILE循环语句,语法“WHILE条件表达式DO循环语句ENDWHILE”;2、REPEAT循环语句,语法...
-
- 热门文章
-
-
VUE中V-IF条件判断改变元素的样式操作
这篇文章主要介绍了VUE中V-IF条件判断改变元素的样式操作,具有很好的参考价值,希望对大家有所帮助。一起跟随想过来看看吧...
-
Discuz如何解决安装时报错run_sql_error
问题环境VMware虚拟机Centos7.3PHP7.0MySQL8.0NGINX1.14Discuz3.4问题还原本地环境为PHP5.6+MySQL5.6在安...
-
低版本VS项目在VS2019无法正常编译的问题
低版本VS项目在VS2019无法正常编译的问题这里指的编译并不准确,只是为了方便说明。后有(未安装),201?...
-
PHP+Redis链表解决高并发下商品超卖问题(实现原理及步骤)
实现原理使用redis链表来做,因为pop操作是原子的,即使有很多用户同时到达,也是依次执行,推荐使用。实现步骤第一步,先将商品库存入队列/**.trigge...
-
Oracle数据库的实例/表空间/用户/表之间关系简单讲解
完整的Oracle数据库通常由两部分组成:Oracle数据库和数据库实例。Oracle是一种数据库管理系统,是一种关系型的数据库管理系统。我们用这些高级权限账号...
-