慢查询日志概念mysql
MySQL 的慢查询日志是 MySQL 提供的一种日志记录,它用来记录在 MySQL 中查询响应时间超过阈值的语句,具体指响应时间超过sql
long_query_time 值的 SQL,会被记录到慢查询日志。long_query_time 的默认值是 10s,意思是查询响应时间超过 10s 的 SQL语句。默数据库
认状况下,MySQL 是不开启慢查询日志的,须要咱们手动设置这个参数值,固然,若是不是调优须要的话,通常不建议开启慢查询日志,服务器
由于开启慢查询日志或多或少会带来必定性能的影响。慢查询日志支持将日志记录写入日志文件,也支持将日志记录写入数据表。性能
慢查询日志参数测试
slow_query_log:表示是否开启慢查询日志,OFF表示禁用,ON表示开启3d
slow_query_log_file:MySQL 慢查询日志存储路径。能够不设置该参数,系统会默认给一个缺省值的文件host_name-slow.log日志
long_query_time:慢查询时间阈值,默认状况下值为 10sblog
log_queries_not_using_indexes:表示不使用索引的查询超出 long_time_query 的值也会被记录到日志中,默认值是 OFF表示禁用索引
log_output:表示存储慢查询日志方式,log_output='FILE' 表示将日志存入文件,log_output=‘TABLE’ 表示将日志存入数据表 mysql.slow_log
。MySQL 同时支持两种日志存储方式,配置的时候以逗号分隔开,如:log_output='FILE,TABLE'。通常状况下建议将日志记录到
文件中,若是将日志记录到数据表中须要耗费更多系统资源
慢查询日志配置
默认状况下,slow_query_log 是禁用的,能够经过设置 slow_query_log 的值开启,以下所示:
开启慢查询日志:
使用 set global slow_query_log=1 开启慢查询日志只对当前数据库生效,若是 MySQL 重启后则会失效。若是要永久生效,就须要修改配置文件
my.cnf(Linux 下的叫法),若是是 win 系统通常叫 my.ini,如以下所示:
修改 my.ini 文件,增长或修改参数 slow_query_log 和 slow_query_log_file 后,而后重启 MySQL 服务器,以下所示:
如今已经开启了慢查询日志,那么什么样的 SQL 才会被记录到日志中呢?这个就由 long_query_time 控制,默认状况下 long_query_time 的值为 10s,可
以使用命令修改,也能够经过修改配置文件修改,对于运行时间恰好等于 long_query_time 的状况是不会被记录下来的,以下:
修改 long_query_time 值
执行修改操做以后,须要从新链接或打开一个会话才能看到修改的值 或者 使用 show global variable like '%long_query_time%' 查看
咱们来测试一下,在 MySQL 中执行下面 SQL 语句,而后咱们去检查对应的慢日志:
log_output 是用来指定存储日志的方式,操做以下:
设置慢日志存储方式:
执行 select sleep(10); 以下所示:
系统变量 log_queries_not_using_indexes 未使用索引的查询也会被记录到慢日志中,若是调优的话,建议开启这个选项,开启这个选项后 index full scan 的sql 也会被记录到日志中
这个开启以后慢查询日志可能会增加的很快,能够设定 log_throttle_queries_not_using_indexes 变量来限制,默认值是 0,也就是不限制,若是该变量
值大于 0 如:log_throttle_queries_not_using_indexes = 100 表示每秒记录100条不使用索引的 SQL 语句到慢查询日志中
默认状况下,管理类的 SQL 语句也不会被记录到慢查询日志中,log_slow_admin_statements 变量表示是否将管理类的 SQL 语句记录到慢查询日中,管理
类的 SQL 语句包含:ALTER TABLE, ANALYZE TABLE, CHECK TABLE, CREATE INDEX, DROP INDEX, OPTIMIZE TABLE, and REPAIR TABLE
MySQL 的从库默认不记录慢查询,若是要开启从库的慢查询须要设定 log_slow_slave_statements
若是要查询有多少条慢查询记录,可使用系统变量,以下: