MySQL数据库之使用MySQL Slow Log来解决MySQL CPU占用高的问题
小标 2018-12-06 来源 : 阅读 1169 评论 0

摘要:本文主要向大家介绍了MySQL数据库之使用MySQL Slow Log来解决MySQL CPU占用高的问题 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助。

本文主要向大家介绍了MySQL数据库之使用MySQL Slow Log来解决MySQL CPU占用高的问题 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助。


           但是怎么找到是哪个SQL语句的执行时间过长呢?可以通过MySQL Slow Log来找,详解如下。 

首先找到MySQL的配置文件my.cnf,根据不同版本的mysql开启慢查询的配置也不一样 


mysql 5.0 

[mysqld] 
long_query_time = 1 
log-slow-queries = /var/log/mysql/slow.log 


mysql 5.1 

[mysqld] 
long_query_time = 1 
slow_query_log=1 
slow_query_log_file = /var/log/mysql/slow.log 


long_query_time 是指执行超过多久的sql会被log下来,这里是1秒。 
log-slow-queries和slow_query_log_file 设置把日志写在哪里 


把上述参数打开,运行一段时间,就可以关掉了,省得影响生产环境 

接下来就是分析了,我这里的文件名字叫 /var/log/mysql/slow.log。 
先mysqldumpslow –help下,主要用的是 


-s ORDER what to sort by (t, at, l, al, r, ar etc), ‘at' is default 
-t NUM just show the top n queries 
-g PATTERN grep: only consider stmts that include this string 

-s,是order的顺序,说明写的不够详细,主要有 
c,t,l,r和ac,at,al,ar,分别是按照query次数,时间,lock的时间和返回的记录数来排序,前面加了a的时倒序 
-t,是top n的意思,即为返回前面多少条的数据 
-g,后边可以写一个正则匹配模式,大小写不敏感的 


mysqldumpslow -s c -t 20 /var/log/mysql/slow.log 
mysqldumpslow -s r -t 20 /var/log/mysql/slow.log 

上述命令可以看出访问次数最多的20个sql语句和返回记录集最多的20个sql。 


mysqldumpslow -t 10 -s t -g “left join” /var/log/mysql/slow.log 
这个是按照时间返回前10条里面含有左连接的sql语句。 

用了这个工具就可以查询出来那些sql语句是性能的瓶颈,进行优化,比如加索引,该应用的实现方式等。

   

本文由职坐标整理并发布,希望对同学们学习MySQL有所帮助,更多内容请关注职坐标数据库MySQL数据库频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程