加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

如何在MySQL中启动慢查询日志

发布时间:2022-02-15 10:12:31 所属栏目:MySql教程 来源:互联网
导读:如何在MySQL中开启慢查询日志?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 (1)配置开启 Linux: 在mysql配置文件 my.cnf 中增加如下语句: log-slow-queries=/var/lib/mysql/slowqu
      如何在MySQL中开启慢查询日志?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
 
(1)配置开启
 
Linux:
 
在mysql配置文件 my.cnf 中增加如下语句:
 
log-slow-queries=/var/lib/mysql/slowquery.log #指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log
long_query_time=5 #记录超过的时间,默认为10s,这里设置为查询时间超过5s的查询语句
log-queries-not-using-indexes = on # 列出没有使用索引的查询语句
#log-queries-not-using-indexes 是否记录所有没有使用索引的query,可以根据情况决定是否开启
#log-long-format 是否记录所有的查询记录,包括没有使用索引的查询
Windows:
 
在 my.ini 的[mysqld]添加如下语句(语句选项以及释义同上):
 
log-slow-queries = E:mysqllogmysqlslowquery.log
long_query_time = 5
(2)查看方式
 
Linux:
 
使用mysql自带命令mysqldumpslow查看
 
常用命令
 
-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
eg:
 
-s,是order的顺序,说明写的不够详细,俺用下来,包括看了代码,主要有 c,t,l,r和ac,at,al,ar,分别是按照query次数,时间,lock的时间和返回的记录数来排序,前面加了a的时倒序
 
-t,是top n的意思,即为返回前面多少条的数据
 
-g,后边可以写一个正则匹配模式,大小写不敏感的
 
具体命令使用如下:
 
mysqldumpslow -s c -t 20 host-slow.log
 
mysqldumpslow -s r -t 20 host-slow.log
上述命令可以看出访问次数最多的20个sql语句和返回记录集最多的20个sql。
 
mysqldumpslow -t 10 -s t -g “left join” host-slow.log这个是按照时间返回前10条里面含有左连接的sql语句。
 
Windows:
 
当你是第一次开启mysql的慢查询,会在你指定的目录下创建这个记录文件,本文就是mysqlslowquery.log,这个文件的内容大致如下(第一次开启MYSQL慢查询的情况下)
 
E:webmysqlbinmysqld, Version: 5.4.3-beta-community-log (MySQL Community Server (GPL)). started with:
TCP Port: 3306, Named Pipe: (null)
Time Id Command Argument
 
可以通过如下的命令来查看慢查询的记录数:
 
mysql> show global status like ‘%slow%';
+---------------------+-------+
| Variable_name    | Value |
+---------------------+-------+
| Slow_launch_threads | 0   |
| Slow_queries    | 0   |
+---------------------+-------+
测试
 
1.执行一条慢查询SQL语句
 
mysql> select sleep(2);
2.查看是否生成慢查询日志
 
ls /usr/local/mysql/data/slow.log
看完上述内容,你们掌握如何在MySQL中开启慢查询日志的方法了吗?

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读