zoukankan      html  css  js  c++  java
  • MySQL-慢查询日志

    慢查询日志功能默认不开启,其记录了执行时间超过参数long_query_time的值(默认是10),且访问的行数超过了参数min_examined_row_limit的值得SQL语句。

    mysql> show variables like 'long_query_time'G
    *************************** 1. row ***************************
    Variable_name: long_query_time
            Value: 10.000000
    1 row in set (0.00 sec)
    
    mysql>
    

    获取表的锁的时间不算在sql执行时间内。语句执行结束后,才会写到慢查询日志。

    1.开启慢查询日志功能(不同版本开启方法不一样)

    5.1.6之前版本:

      --log-slow-queries[=file_name]
    5.1.12版本:

      --slow_query_log[={0|1}] 
    5.1.29版本

      --slow_query_log[={0|1}]

      --slow_query_log_file=file_name

    mysql> show variables like 'slow_query%';
    +---------------------+---------------------------------+
    | Variable_name       | Value                           |
    +---------------------+---------------------------------+
    | slow_query_log      | ON                              |
    | slow_query_log_file | /var/mysql/data/dbtest-slow.log |
    +---------------------+---------------------------------+
    2 rows in set (0.00 sec)
    
    mysql> 
    

    2.慢查询日志格式

    慢查询日志可以以file格式输出,也可以以数据库表格式输出

    mysql> show variables like 'log_output';
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | log_output    | FILE  |
    +---------------+-------+
    1 row in set (0.00 sec)
    
    mysql> set global log_output='table';
    Query OK, 0 rows affected (0.00 sec)
    
    mysql> show variables like 'log_output';
    +---------------+-------+
    | Variable_name | Value |
    +---------------+-------+
    | log_output    | TABLE |
    +---------------+-------+
    1 row in set (0.00 sec)
    
    mysql> 
    

    设置为table格式后,输出内容在mysql.slow_log表中。

    此外,可以使用mysqldumpslow工具分析慢查询日志

    3.缺省的慢查询日志名字为

      host_name-slow.log

    4.与慢查询有关的参数
    如果运行的语句没有使用索引,开启log_queries_not_using_indexes后,数据库会将sql语句记录到慢查询日志文件中。

    mysql> show variables like 'log_queries_not_using_indexes';
    +-------------------------------+-------+
    | Variable_name                 | Value |
    +-------------------------------+-------+
    | log_queries_not_using_indexes | OFF   |
    +-------------------------------+-------+
    1 row in set (0.00 sec)
    
    mysql> 
    

    MySQL 5.6.5新增了一个参数log_throttle_queries_not_using_indexes,表示每分钟允许记录到slow log的且未使用索引的sql语句次数,默认是0,表示没有限制。

  • 相关阅读:
    eclipse-SDK-3.7-win32;eclipse-java-indigo-win32;eclipse-jee-indigo-win32 区别(ZZ)
    Marketplace Client- Download
    Log4J2基本配置
    Map 迭代 两种方法
    Python Argparse模块
    Python操作Memcached
    MySQL参数调优
    Nginx调优
    JavaScript知识点总结[部分]
    python optparser模块
  • 原文地址:https://www.cnblogs.com/abclife/p/5101701.html
Copyright © 2011-2022 走看看