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
MySQL中慢查询SQL语句查找和分析_第1张图片

  • 常用命令
    得到返回记录集最多的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;

MySQL中慢查询SQL语句查找和分析_第2张图片

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

MySQL中慢查询SQL语句查找和分析_第3张图片
converting HEAP to MyISAM 查询结果太大,内存数据写到磁盘
Creating tmp table 拷贝数据到临时表,用完再删除
Copying to tmp table on disk 内存中临时表数据写到磁盘
locked
这四项最耗时耗资源

  • 其它可选参数
    MySQL中慢查询SQL语句查找和分析_第4张图片

通用日志

不建议生产环境开启

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中慢查询SQL语句查找和分析_第5张图片

  • 查看输出
mysql> SELECT * FROM mysql.general_log;

你可能感兴趣的:(数据存储,mysql)