Mysql数据库优化之开启慢查询日志
2015-12-27 00:00
633 查看
摘要: MySQL记录下查询超过指定时间的语句,使用mysql慢查询日志对有效率问题的sql进行监控
Mysql版本:5.5.18
下面将介绍两种方式开启mysql开启慢查询的方法
1. 配置文件修改(重启mysql后不会失效,缺点是修改完配置文件后需要重启)
打开mysql配置文件(安装方式不同配置文件路径不同)
#vim /etc/my.cnf (将一下内容添加进入配置文件)
解释:long_query_time = 1 #指执行超过1S的SQL会被记录下来
slow_query_log=1 #1表示开启慢查询,0表示关闭慢查询
slow-query-log-file = /home/mysql/log/slow.log #慢查询日志存储的路径
#log-queries-not-using-indexes #无需添加,如果需要记录下来没有索引的查询,请添加此项,否则会被刷屏的
修改完成后,记得重启数据库
重启后查看是否打开mysql 慢查询(ON表示开启,OFF表示关闭)
查询无索引的语句是否被记录 (OFF没有开启)
查看超过多长时间的sql会被记录下来
2. mysql命令行修改
查询命令参照上面
执行完命令之后,使用上面的语句进行查看,是否开启,修改完成后不用重启数据库,但是重启数据库就会失效;
Mysql版本:5.5.18
下面将介绍两种方式开启mysql开启慢查询的方法
1. 配置文件修改(重启mysql后不会失效,缺点是修改完配置文件后需要重启)
打开mysql配置文件(安装方式不同配置文件路径不同)
#vim /etc/my.cnf (将一下内容添加进入配置文件)
[mysqld] long_query_time = 1 slow_query_log = 1 slow-query-log-file = /home/mysql/log/slow.log
解释:long_query_time = 1 #指执行超过1S的SQL会被记录下来
slow_query_log=1 #1表示开启慢查询,0表示关闭慢查询
slow-query-log-file = /home/mysql/log/slow.log #慢查询日志存储的路径
#log-queries-not-using-indexes #无需添加,如果需要记录下来没有索引的查询,请添加此项,否则会被刷屏的
修改完成后,记得重启数据库
重启后查看是否打开mysql 慢查询(ON表示开启,OFF表示关闭)
mysql> show variables like '%slow%'; +---------------------+-------------------------------------+ | Variable_name | Value | +---------------------+-------------------------------------+ | log_slow_queries | ON | | slow_launch_time | 2 | | slow_query_log | ON | | slow_query_log_file | /home/mysql/log/slow.log | +---------------------+-------------------------------------+ 4 rows in set (0.00 sec)
查询无索引的语句是否被记录 (OFF没有开启)
mysql> show variables like 'log_queries_not_using_indexes'; +-------------------------------+-------+ | Variable_name | Value | +-------------------------------+-------+ | log_queries_not_using_indexes | OFF | +-------------------------------+-------+ 1 row in set (0.00 sec)
查看超过多长时间的sql会被记录下来
mysql> show variables like '%long_query%'; #时间单位为秒 +-----------------+----------+ | Variable_name | Value | +-----------------+----------+ | long_query_time | 1.000000 | +-----------------+----------+ 1 row in set (0.00 sec)
2. mysql命令行修改
查询命令参照上面
mysql> set global long_query_time=1; Query OK, 0 rows affected (0.00 sec) mysql> set global slow_query_log=1; Query OK, 0 rows affected (0.02 sec) mysql> set global slow_query_log_file = '/home/mysql/log/slow.log'; Query OK, 0 rows affected (0.00 sec) mysql> set global log_queries_not_using_indexes=off; #如果不需要不用开启 Query OK, 0 rows affected (0.00 sec)
执行完命令之后,使用上面的语句进行查看,是否开启,修改完成后不用重启数据库,但是重启数据库就会失效;
相关文章推荐
- mysql的数据字符集从latin1转化成utf8
- mysql优化总结。。
- mysql如何添加用户 删除用户 修改用户密码
- Mysql AB复制
- MySQL常用字符集
- 编译安装mysql
- MySql5.7.10初始化
- MySQL事务处理
- mysql5.7 zip windows下安装
- 进军服务器了,转点mysql操作命令
- 数据库_mysql_基础
- MYSQL API以及基本操作介绍以及,MYSQL_FIELD介绍
- mysql5.7新特性探究
- mysql5.7.10 zip windows安装
- 【MySql】 BlackHole :黑洞引擎
- MySQL BlackHole 存储引擎使用
- MySQL----int(M)讲解 (int(3)与int(11)的区别)
- MySQL服务启动脚本
- MYSQL数据丢失讨论
- mysqlbinlog解析的几篇经典文章