mysql慢查询日志

添加慢查询日志:

第一种、修改my.cnf添加(荐):

log-slow-queries=/var/log/slowquery.log

long_query_time=1

重启mysql

第二种、命令下添加:

set global long_query_time=1;

注:long_query_time的值:

5.2.1之前版本最小为1s,如果想支持ms需要打补丁;

MySQL5.21+的版本最小值为0,可以设置0.5(500ms)。

查看慢查询时间值:

mysql> show variables like "%long%";


慢查询分析mysqldumpslow

我们可以通过打开log文件查看得知哪些SQL执行效率低下

[root@localhost mysql]# more slow-query.log                            

# Time: 081026 19:46:34                                                                          

# User@Host: root[root] @ localhost []                                                          

# Query_time: 11 Lock_time: 0 Rows_sent: 1 Rows_examined: 6552961        

select count(*) from t_user;                                                                                

从日志中,可以发现查询时间超过5 秒的SQL,而小于5秒的没有出现在此日志中。

如果慢查询日志中记录内容很多,可以使用mysqldumpslow工具(MySQL客户端安装自带)来对慢查询日志进行分类汇总。mysqldumpslow对日志文件进行了分类汇总,显示汇总后摘要结果。

进入log的存放目录,运行

[root@mysql_data]#mysqldumpslow  slow-query.log                                

Reading mysql slow query log from slow-query.log                            

Count: 2 Time=11.00s (22s) Lock=0.00s (0s) Rows=1.0 (2), root[root]@mysql    

select count(N) from t_user;                                                

mysqldumpslow命令

/path/mysqldumpslow -s c -t 10 /database/mysql/slow-query.log                      

这会输出记录次数最多的10条SQL语句,其中:

-s, 是表示按照何种方式排序,c、t、l、r分别是按照记录次数、时间、查询时间、返回的记录数来排序,ac、at、al、ar,表示相应的倒叙;

-t, 是top n的意思,即为返回前面多少条的数据;

-g, 后边可以写一个正则匹配模式,大小写不敏感的;

例如:

/path/mysqldumpslow -s r -t 10 /database/mysql/slow-log                                

得到返回记录集最多的10个查询。

/path/mysqldumpslow -s t -t 10 -g “left join” /database/mysql/slow-log      

得到按照时间排序的前10条里面含有左连接的查询语句。

使用mysqldumpslow命令可以非常明确的得到各种我们需要的查询语句,对MySQL查询语句的监控、分析、优化是MySQL优化非常重要的一步。开启慢查询日志后,由于日志记录操作,在一定程度上会占用CPU资源影响mysql的性能,但是可以阶段性开启来定位性能瓶颈。


附:

添加错误日志


log-error=/var/log/mysql/logerror.log


==========================================================================

不重启服务,直接配置变量

mysql>set global log_slow_queries=on; 注这个和下面一个有一个为ON,另一个自动为   ON

mysql>set global slow_query_log=on;

mysql> set global slow_query_log_file='/tmp/man.log';

mysql> set global long_query_time=3; #注这个和上面的不同,需要重新登陆才可以使用show看到生效。


注:slow_launch_time跟慢查询日志没有任何关系, 它代表的是thread create的一个阈值


=============================================================

修改配置文件注意:

long_query_time=2

log-long-format #注:不指定该参数默认为long格式可以使用log_long_format,推荐配置文件中统一使用-,short格式mysqldumpslow无法分析。

log-slow-queries=/data/mysqldata/slow-log.log #不能指定成slow_query_log=/data/mysqldata/slow-log.log 指定后重启服务正常启动,但是慢日志不会开启,名字为默认的主机名.log



你可能感兴趣的:(mysql添加慢查询日志)