MySQL中慢查询SQL语句查找和分析

慢查询日志

默认情况下,MySQL数据库没有开启慢查询日志,如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性能影响。

  • 开启慢查询日志
mysql> SHOW VARIABLES LIKE '%slow_query_log%';
mysql> SET GLOBAL slow_query_log = 1;

在这里插入图片描述

  • 查看慢查询日志
    [root@yangjjhost03 ~]# tail -500f /var/lib/mysql/yangjjhost03-slow.log
  • 查询时间,多少秒之前的为慢查询
mysql> SHOW VARIABLES LIKE '%long_query_time%';
  • 修改时间阈值
mysql> SET long_query_time = 5;

mysqldumpslow

日志分析工具 mysqldumpslow
在这里插入图片描述

  • 常用命令
    得到返回记录集最多的10个SQL
    [root@yangjjhost03 ~]# mysqldumpslow -s r -t 10 /var/lib/mysql/yangjjhost03-slow.log
  • 得到访问次数最多的10个SQL
    [root@yangjjhost03 ~]# mysqldumpslow -s c -t 10 /var/lib/mysql/yangjjhost03-slow.log
  • 得到按照时间排序的前10条里面含有关键字的查询语句
    [root@yangjjhost03 ~]# mysqldumpslow -s t -t 10 -g “tbl_emp” /var/lib/mysql/yangjjhost03-slow.log | more

profiling

可以用来分析当前会话中语句执行的资源消耗情況。可以用于SQL的调优的测量
默认情況下,参数处于关闭状态,并保存最近15次的运行结果

mysql> SHOW VARIABLES LIKE 'profiling';
  • 开启profiling
mysql> SET profiling = 1;
  • 查看一个执行计划的总执行时间
mysql> show profiles;

在这里插入图片描述

  • 具体分析一个执行计划中,SQL语句执行过程中的资源消耗情况
    show profile cpu, block io for query n(n为Query_ID)
mysql> show profile cpu, block io for query 4;

在这里插入图片描述
converting HEAP to MyISAM 查询结果太大,内存数据写到磁盘
Creating tmp table 拷贝数据到临时表,用完再删除
Copying to tmp table on disk 内存中临时表数据写到磁盘
locked
这四项最耗时耗资源

  • 其它可选参数
    在这里插入图片描述

通用日志

不建议生产环境开启

mysql> SHOW VARIABLES LIKE'%general_log%';
  • 开启通用查询日志
mysql> SET GLOBAL  general_log = 1;
  • 不希望日志输出到文件,希望输出到表中查看
mysql> SET GLOBAL  log_output = 'TABLE';
mysql> SHOW VARIABLES LIKE'%log_output%';

在这里插入图片描述

  • 查看输出
mysql> SELECT * FROM mysql.general_log;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值