您好,欢迎访问一九零五行业门户网

MySQL中普通、慢查询日志的区别

intro

之前的一篇分享提到,mysql的日志类型可以分为三种,错误日志(error_log),查询日志(query_log),和二进制日志(binary_log),error_log的介绍与用法详见mysql日志之error_log,本文主要介绍general_log和slow_query_log的原理和用法。
通用查询日志通用查询日志(general_log)主要用于查询各client连接数据库时的相关信息与在数据库上执行的sql语句,配置方法为:
1、查询通用查询日志是否开启与其存放路径:
mysql> show variables like "general_log%"; +------------------+------------------------------+| variable_name | value | +------------------+------------------------------+| general_log | off | | general_log_file | /var/lib/mysql/localhost.log | +------------------+------------------------------+ 2 rows in set (0.00 sec)
屏幕输出中general_log和general_log_file记录了当前通用查询日志的开关状态与路径。
2、开启通用查询日志
set global general_log = on
查询是否成功:
mysql> show variables like "general_log%"; +------------------+------------------------------+| variable_name | value | +------------------+------------------------------+| general_log | on | | general_log_file | /var/lib/mysql/localhost.log | +------------------+------------------------------+ 2 rows in set (0.00 sec)
成功。
退出一下看有没有生成并且正确记录:
[root@localhost ~]# cat /var/lib/mysql/localhost.log /usr/sbin/mysqld, version: 5.7.19 (mysql community server (gpl)). started with: tcp port: 3306 unix socket: /var/lib/mysql/mysql.sock time id command argument 2017-08-14t09:33:11.364650z 5 quit 2017-08-14t09:33:20.671113z 6 connect root@localhost on using socket 2017-08-14t09:33:20.671323z 6 query select @@version_comment limit 1 2017-08-14t09:33:22.964610z 6 query show variables like '%log%' 2017-08-14t09:33:24.574224z 6 quit
成功,并且我们可以看到,log不仅记录了sql命令,同时也包括了执行时间、id、命令类型等相关数据
慢查询日志慢查询日志记录了sql语句时间超过了预设的long_query_time的语句,在数据量较大的情况下,可以看看慢查询日志中有哪些语句需要进行优化。
1、慢查询日志的配置
慢查询日志的配置可以在数据库配置文件my.cnf中查到:
[root@localhost ~]# cat /etc/my.cnf | grep -e 'long|slow|not_using_indexes'long_query_time = 1#log-slow-queries = /var/log/mysql/slow.loglog_queries_not_using_indexes
可以看到:
long_query_time = 1的意思是sql语句执行时间超过1s的,对其进行记录;
log-slow-queries = /var/log/mysql/slow.log是对慢查询日志路径的设置;
log_queries_not_using_indexes意思为不使用索引的语句,可以缩小记录的目标
实际配置与通用查询日志相同,在mysql交互界面中输入命令开启慢查询日志:
set slow_query_log = on
2、查询是否成功
[root@localhost ~]# cat /var/lib/mysql/localhost-slow.log /usr/sbin/mysqld, version: 5.7.19 (mysql community server (gpl)). started with: tcp port: 3306 unix socket: /var/lib/mysql/mysql.sock time id command argument
成功。
但注意,slow_query_log可能会记录到与用户权限和密码相关的语句,因此在使用慢查询日志文件时请注意日志的安全保存。
以上就是mysql中普通、慢查询日志的区别的详细内容。
其它类似信息

推荐信息