MySQL开启慢日志和性能分析

开启慢日志

//方法一
修改配置文件my.cnf,在[mysqld]下的下方加入
[mysqld]
//慢查询开启状态
slow_query_log = ON
//慢查询日志存放的位置(这个目录需要MySQL的运行帐号的可写权限,一般设置为MySQL的数据存放目录)
slow_query_log_file = /usr/local/mysql/data/slow.log
//查询超过多少秒才记录
long_query_time = 1


//方法二
//查看慢查询相关参数
mysql> show variables like 'slow_query%';
mysql> show variables like 'long_query_time';
//设置方法
//将 slow_query_log 全局变量设置为“ON”状态
mysql> set global slow_query_log='ON';
//设置慢查询日志存放的位置
mysql> set global slow_query_log_file='/usr/local/mysql/data/slow.log';
//查询超过1秒就记录
mysql> set global long_query_time=1;

//重启MySQL服务
service mysqld restart

开启性能分析

//查看当前系统有多少慢查询数量
show status like 'slow_queries';
//使用慢查询日志分析工具mysqldumpslow,查看下帮助文档
mysqldumpslow --help
-s: 是表示按照何种方式排序:
    c: 访问次数
    l: 锁定时间
    r: 返回记录
    t: 查询时间
    al: 平均锁定时间
    ar: 平均返回记录数
    at: 平均查询时间 (默认方式)
    ac: 平均查询次数
-t: 即为返回前面多少条的数据;
-g: 后边搭配一个正则匹配模式,大小写不敏感的;

//mysqldumpslow是perl程序,需要下载perl编译器
https://www.perl.org/get.html
//使用,工具查询时间查看前五条的慢SQL
mysqldumpslow -s -t 5 /data/mysql/mysql-slow.log。
//得到返回记录集最多的10个SQL
mysqldumpslow -s r -t 10 /data/mysql/mysql-slow.log
//得到访问次数最多的10个SQL
mysqldumpslow -s c -t 10 /data/mysql/mysql-slow.log
//得到按照时间排序的前10条里面含有左连接的查询语句
mysqldumpslow -s t -t 10 -g "left join" /data/mysql/mysql-slow.log
//另外建议在使用这些命令时结合 | 和more 使用 ,否则有可能出现爆屏情况
mysqldumpslow -s r -t 10 /data/mysql/mysql-slow.log | more

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值