mysql配置调优-开启慢查询日志-slow_query_log

工作中,会遇到需要查看mysql的top 20 慢sql,逐个进行优化,加上必要的索引这种需求,这时就需要开启数据库的慢查询日志的功能

1.查询当前慢查询日志的状态

# 默认为关闭状态

mysql
----------------------------
show variables like "%slow_query_log%";
----------------------------

# 实例演示:

mysql> show variables like "%slow_query_log%";
+---------------------+-------------------------------------------+
| Variable_name       | Value                                     |
+---------------------+-------------------------------------------+
| slow_query_log      | OFF                                       |
| slow_query_log_file | /usr/local/mysql/data/1055-mysql-slow.log |
+---------------------+-------------------------------------------+
2 rows in set (0.00 sec)

# 可以看到,慢查询日志的状态和默认的慢查询日志的文件

[root@1055-mysql ~]# cd /usr/local/mysql/data/
[root@1055-mysql data]# ll
总用量 568888
-rw-r----- 1 mysql root       5888 11月  7 2016 1055-mysql.err
-rw-rw---- 1 mysql mysql 56 11月 7 2016 auto.cnf -rw-rw---- 1 mysql mysql 281018368 12月 4 11:15 ibdata1 -rw-rw---- 1 mysql mysql 50331648 12月 4 11:15 ib_logfile0 -rw-rw---- 1 mysql mysql 50331648 12月 12 2017 ib_logfile1 drwx------ 2 mysql mysql 4096 11月 7 2016 mysql -rw-rw---- 1 mysql mysql 120 12月 4 11:15 mysql-bin.000123 -rw-rw---- 1 mysql mysql 120 12月 4 11:15 mysql-bin.000124 -rw-rw---- 1 mysql mysql 78 12月 4 11:15 mysql-bin.index drwx------ 2 mysql mysql 4096 11月 7 2016 performance_schema

# 但实际在该位置并未生成慢查询日志的文件

2.手动开启慢查询日志

# 登陆mysql进行设置

mysql
----------------------------
set global slow_query_log=on;
----------------------------

# 实例演示:

mysql> set global slow_query_log=on;
Query OK, 0 rows affected (0.02 sec)

mysql> show variables like "%slow_query_log%";
+---------------------+-------------------------------------------+
| Variable_name       | Value                                     |
+---------------------+-------------------------------------------+
| slow_query_log      | ON                                        |
| slow_query_log_file | /usr/local/mysql/data/1055-mysql-slow.log |
+---------------------+-------------------------------------------+
2 rows in set (0.00 sec)

# 可以看到,慢查询日志的状态更改了

[root@1055-mysql data]# ll
总用量 568892
-rw-r----- 1 mysql root       5888 11月  7 2016 1055-mysql.err
-rw-rw---- 1 mysql mysql       175 1月  22 18:23 1055-mysql-slow.log
-rw-rw---- 1 mysql mysql 56 11月 7 2016 auto.cnf -rw-rw---- 1 mysql mysql 281018368 12月 4 11:15 ibdata1 -rw-rw---- 1 mysql mysql 50331648 12月 4 11:15 ib_logfile0 -rw-rw---- 1 mysql mysql 50331648 12月 12 2017 ib_logfile1 drwx------ 2 mysql mysql 4096 11月 7 2016 mysql -rw-rw---- 1 mysql mysql 120 12月 4 11:15 mysql-bin.000123 -rw-rw---- 1 mysql mysql 120 12月 4 11:15 mysql-bin.000124 -rw-rw---- 1 mysql mysql 78 12月 4 11:15 mysql-bin.index drwx------ 2 mysql mysql 4096 11月 7 2016 performance_schema

# 检查文件发现自动生成了慢查询日志的文件

3.修改mysql配置文件保证永久生效

# 由于慢查询日志记录的信息比较多,会影响mysql的性能,所以生产环境不建议长期开启

vim /etc/my.cnf
-----------------------------------
slow_query_log=1
slow_query_log_file=/usr/local/mysql/data/slow-query.log
-----------------------------------

# 其他可用的配置参数

long_query_time=1           # 慢查询日志的时间定义(秒),默认为10秒,多久就算慢查询的日志
log_queries_not_using_indexes=1    # 将所有没有使用带索引的查询语句全部写到慢查询日志中

# 修改完配置重启即可生效

==== 完毕,呵呵呵呵 ==== 

转载于:https://www.cnblogs.com/tssc/p/10305470.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值