Mysql_慢查询日志

慢查询日志功能

show variables like 'slow_query_log';
show variables like 'slow_query_log_file';
show variables like 'long_query_time';

--开启慢查询日志记录
set global slow_query_log = on;

--配置文件my.cnf中开启,需重启mysql服务
[mysqld]
slow_query_log=1
slow_query_log_file=/var/lib/mysql/data/hostname-slow.log
long_query_time=10
log_output=FILE

  • Mysql的慢查询日志是Mysql提供的一种日志记录,它用来记录在Mysql中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL(“等于”是不会被记录的),则会被记录到慢查询日志中。
  • long_query_time的默认值为10,意思是运行10秒以上的语句。
  • 由此来查看哪些SQL超出了我们的最大忍耐时间,比如一条sql执行超过5秒,我们就算慢sql,希望能收集超过5秒的sql,结合explain进行全面分析。
  • 默认情况下,Mysql数据库没有开启慢查询,需要手动来设置这个参数。
  • 如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会带来一定的性能影响。
  • 慢查询日志支持将日志记录写入文件,或者写入表中。

慢查询日志分析工具(mysqldumpslow)

# 查看帮助
mysqldumpslow --help

# 得到返回记录集最多的10个sql
mysqldumpslow -s r -t 10 /var/lib/mysql/data/hostname-slow.log

# 得到访问次数最多的10个Sql
mysqldumpslow -s c -t 10 /var/lib/mysql/data/hostname-slow.log

# 得到按照时间排序的前10条里面含有左连接的查询语句
mysqldumpslow -s t -t 10 -g "lsef join" /var/lib/mysql/data/hostname-slow.log

# 另外建议在使用这些命令时结合其他工具使用
mysqldumpslow -s r -t 10 /var/lib/mysql/data/hostname-slow.log | more
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值