• 慢查询


    慢查询日志,顾名思义,就是查询慢的日志,是指mysql记录所有执行超过long_query_time参数设定的时间阈值的SQL语句的日志。该日志能为SQL语句的优化带来很好的帮助。默认情况下,慢查询日志是关闭的,要使用慢查询日志功能,首先要开启慢查询日志功能。

    慢查询基本配置

     slow_query_log 启动停止技术慢查询日志

    slow_query_log_file 指定慢查询日志得存储路径及文件(默认和数据文件放一起)

     long_query_time 指定记录慢查询日志SQL执行时间得伐值(单位:秒,默认10秒)

    log_queries_not_using_indexes  是否记录未使用索引的SQL

     log_output 日志存放的地方【TABLE】【FILE】【FILE,TABLE】

    配置了慢查询后,它会记录符合条件的SQL

    包括:

     查询语句

    数据修改语句

     已经回滚得SQL

    show VARIABLES like '%slow_query_log%'
    
    show VARIABLES like '%slow_query_log_file%'
    
    show VARIABLES like '%long_query_time%'
    
    show VARIABLES like '%log_queries_not_using_indexes%'
    
    show VARIABLES like 'log_output'
    
    
    set global long_query_time=0;   ---默认10秒,这里为了演示方便设置为0 
    
    set GLOBAL  slow_query_log = 1; --开启慢查询日志
    
    set global log_output='FILE,TABLE'  --项目开发中日志只能记录在日志文件中,不能记表中
    
    
    设置完成后,查询一些列表可以发现慢查询的日志文件里面有数据了。

      

    第一行:用户名 、用户的IP信息、线程ID号

    第二行:执行花费的时间【单位:毫秒】

    第三行:执行获得锁的时间

    第四行:获得的结果行数

    第五行:扫描的数据行数

    第六行:这SQL执行的具体时间

    第七行:具体的SQL语句

    慢查询分析 

         慢查询分析工具 

       Mysqldumpslow  

    常用的慢查询日志分析工具,汇总除查询条件外其他完全相同的SQL,并将分析结果按照参数中所指定的顺序输出。

    mysqldumpslow -s r -t 10 slow-mysql.log
    -s order (c,t,l,r,at,al,ar) 
             c:总次数
             t:总时间
             l:锁的时间
             r:总数据行
             at,al,ar  :t,l,r平均数  【例如:at = 总时间/总次数】
    
      -t  top   指定取前面几天作为结果输出
    
    mysqldumpslow.pl -s t -t 10 D:	est-slow.log

     pt_query_digest

    是用于分析mysql慢查询的一个工具,与mysqldumpshow工具相比,py-query_digest 工具的分析结果更具体,更完善。

    有时因为某些原因如权限不足等,无法在服务器上记录查询。这样的限制我们也常常碰到。

      

     perl .pt-query-digest  --explain h=127.0.0.1,u=root,p=root1234% D: est-slow.log

  • 相关阅读:
    sort-list leetcode C++
    sum-root-to-leaf-numbers leetcode C++
    sum-root-to-leaf-numbers leetcode C++
    path-sum-ii leetcode C++
    path-sum-ii leetcode C++
    0139 函数的两种声明方式
    0138 函数可以调用另外一个函数
    0137 函数案例:数组翻转、冒泡排序、判断闰年
    0136 JavaScript中 arguments 的使用
    0135 函数的返回值:return 语句、终止函数 、只能返回一个值、没有 return 返回 undefined、break &continue&return 的区别
  • 原文地址:https://www.cnblogs.com/qin1993/p/12118851.html
Copyright © 2020-2023  润新知