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


本文摘自PHP中文网,作者一个新手,侵删。


Intro

1

<br>


之前的一篇分享提到,MySQL的日志类型可以分为三种,错误日志(error_log),查询日志(query_log),和二进制日志(binary_log),error_log的介绍与用法详见MySQL日志之error_log,本文主要介绍general_log和slow_query_log的原理和用法。

通用查询日志

通用查询日志(general_log)主要用于查询各client连接数据库时的相关信息与在数据库上执行的SQL语句,配置方法为:

1、查询通用查询日志是否开启与其存放路径:

1

2

3

4

5

6

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_loggeneral_log_file记录了当前通用查询日志的开关状态与路径。

2、开启通用查询日志

    set global general_log = ON

查询是否成功:

1

2

3

4

5

6

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)

成功。

退出一下看有没有生成并且正确记录:

1

2

3

4

5

6

7

8

9

[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中查到:

1

[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交互界面中输入命令开启慢查询日志:

1

set slow_query_log = ON

2、查询是否成功

1

2

3

4

[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中普通、慢查询日志的区别的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

关于mysql性能调优你必须了解的15个重要变量(小结)

mysql什么是事务处理 ?(代码示例)

云服务器centos7搭建mysql数据库(学习记录)

怎么查看mysql数据库表结构图

mysql router的安装部署

一篇文章带你深入了解mysql触发器

mysql中如何加密存储

mysql连接不了服务器怎么办

mysql如何删除多个表格数据库数据

mysql启动时innodb引擎被禁用了怎么办

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...