精华内容
下载资源
问答
  • 内涵 mysqlsla-2.03.tar.tar 包 mysqlsla之linux安装及使用.docx man_mysqlsla.txt
  • MySQL慢日志查询分析方法与工具

    万次阅读 2018-05-08 14:51:13
    MySQL中的日志包括:错误日志、二进制...2)查询日志:记录所有执行时间超过long_query_time秒的所有查询或者不使用索引的查询mysql slow log 是用来记录执行时间较长(超过long_query_time秒)的sql的一种日志工具...

    MySQL中的日志包括:错误日志、二进制日志、通用查询日志、慢查询日志等等。这里主要介绍下比较常用的两个功能:通用查询日志和慢查询日志。

    1)通用查询日志:记录建立的客户端连接和执行的语句。

    2)慢查询日志:记录所有执行时间超过long_query_time秒的所有查询或者不使用索引的查询

    MySQL日志文件系统的组成
       a、错误日志:记录启动、运行或停止mysqld时出现的问题。
       b通用日志:记录建立的客户端连接和执行的语句。
       c、更新日志:记录更改数据的语句。该日志在MySQL 5.1中已不再使用。
       d二进制日志:记录所有更改数据的语句。还用于复制。
       e慢查询日志:记录所有执行时间超过long_query_time秒的所有查询或不使用索引的查询。
       f、Innodb日志:innodb redo log

     缺省情况下,所有日志创建于mysqld数据目录中。
       可以通过刷新日志,来强制mysqld来关闭和重新打开日志文件(或者在某些情况下切换到一个新的日志)。
       当你执行一个FLUSH LOGS语句或执行mysqladmin flush-logs或mysqladmin refresh时,则日志被老化。
       对于存在MySQL复制的情形下,从复制服务器将维护更多日志文件,被称为接替日志。

    同大多数关系型数据库一样,日志文件是MySQL数据库的重要组成部分。MySQL有几种不同的日志文件,通常包括错误日志文件,二进制日志,通用日志,慢查询日志,等等。这些日志可以帮助我们定位mysqld内部发生的事件,数据库性能故障,记录数据的变更历史,用户恢复数据库等等。今天我们要讲的是如何分析和查询mysql慢日志(主要影响程序调用和前端数据呈现)。

    mysql slow log 是用来记录执行时间较长(超过long_query_time秒)的sql的一种日志工具

    启用 slow log

    有两种启用方式:
    1, 在my.cnf 里 通过 log-slow-queries[=file_name]
    2, 在mysqld进程启动时,指定--log-slow-queries[=file_name]选项

    比较的五款常用工具

    mysqldumpslow, mysqlsla, myprofi, mysql-explain-slow-log, mysqllogfilter

    开源的MySQL慢日志查询监控工具

    pmm server、Navicat、mysqltop(天兔Lepus)、Box Anemometer、explain、pt-query-digest

    慢查询日志
       慢查询日志是将mysql服务器中影响数据库性能的相关SQL语句记录到日志文件,通过对这些特殊的SQL语句分析,改进以达到提高数据库性能的目的。
       通过使用--slow_query_log[={0|1}]选项来启用慢查询日志。所有执行时间超过long_query_time秒的SQL语句都会被记录到慢查询日志。
       缺省情况下hostname-slow.log为慢查询日志文件安名,存放到数据目录,同时缺省情况下未开启慢查询日志。
       缺省情况下数据库相关管理型SQL(比如OPTIMIZE TABLE、ANALYZE TABLE和ALTER TABLE)不会被记录到日志。
       对于管理型SQL可以通过--log-slow-admin-statements开启记录管理型慢SQL。
       mysqld在语句执行完并且所有锁释放后记入慢查询日志。记录顺序可以与执行顺序不相同。获得初使表锁定的时间不算作执行时间。
       
       可以使用mysqldumpslow命令获得日志中显示的查询摘要来处理慢查询日志。
       用查询缓存处理的查询不加到慢查询日志中,表有零行或一行而不能从索引中受益的查询也不写入慢查询日志。
       MySQL服务器按以下顺序记录SQL是否写入到慢查询日志
      a. The query must either not be an administrative statement, or --log-slow-adminstatements must have been specified.
     b. The query must have taken at least long_query_time seconds, or log_queries_not_using_indexes must be enabled and the query used no indexes for row lookups.
        c. The query must have examined at least min_examined_row_limit rows.
     d. The query must not be suppressed according to the log_throttle_queries_not_using_indexes setting.

    mysqldumpslow是mysql自带的用来分析慢查询的工具,当然不止这一种工具,还有percona-toolkit是percona公司出的一组命令行工具的集合,用来执行各种通过手工执行非常复杂和麻烦的mysql相关任务,包含以下内容:

    检查master和slave数据一致性/记录有效的归档/服务器信息汇总/分析和统计日志,为了省事这块使用mysqldumpslow命令做分析。

    需要开启mysql的慢查询日志,否则无法进行统计分析,开启mysql慢查询日志需要在mysql的配置文件中进行如下配置:

    1
    2
    3
    slow_query_log=1 #定义超过1秒的查询计数到变量Slow_queries
    slow-query-log- file =mysql-slow.log
    long_query_time=1

    1.1 简介

    开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。

    1.2 登录数据库查看

    [root@localhost lib]# mysql –uroot

    因为没有设置设置密码,有密码的在 mysql –uroot –p 接密码

    1.2.1 进入MySql 查询是否开了慢查询

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

    参数说明:

    1. slow_query_log 慢查询开启状态  OFF 未开启 ON 为开启
    2. slow_query_log_file 慢查询日志存放的位置(这个目录需要MySQL的运行帐号的可写权限,一般设置为MySQL的数据存放目录)

    1.2.2 查看慢查询超时时间

    mysql> show variables like 'long%';
    
    +-----------------+-----------+
    
    | Variable_name  | Value   |
    
    +-----------------+-----------+
    
    | long_query_time | 10.000000 |
    
    +-----------------+-----------+
    
    1 row in set (0.00 sec)
    

    long_query_time 查询超过多少秒才记录   默认10秒 修改为1秒

    1.3 修改方法1:(不推荐)

    方法一:优点临时开启慢查询,不需要重启数据库  缺点:MySql 重启慢查询失效

    推荐:根据业务需求,建议使用第二种,临时可以用第一种

    默认情况下slow_query_log的值为OFF,表示慢查询日志是禁用的,可以通过设置slow_query_log的值来开启,如下所示::是否开启慢查询日志,1表示开启,0表示关闭。

    1.3.1 查看是否开启慢查询

    mysql> show variables like '%slow_query_log%';
    
    +---------------------+--------------------------------------------+
    
    | Variable_name    | Value                   |
    
    +---------------------+--------------------------------------------+
    
    | slow_query_log   | OFF                    |
    
    | slow_query_log_file | /application/mysql/data/localhost-slow.log |
    
    +---------------------+--------------------------------------------+
    
    2 rows in set (0.01 sec)
    

    输入 语句修改(重启后失效,建议在/etc/my.cnf中修改永久生效)

    mysql> set global slow_query_log=1;
    
    Query OK, 0 rows affected (0.11 sec)
    

    1.3.2 再次查看

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

    1.4 修改方法2:(推荐)

    修改 MySql 慢查询,好多人不知道my.cnf 路径,可以用 find 查找

    备注:我的MySQL 是编译的 路径为 /etc/my.cnf (一般都是这里)

    [root@localhost log]# find / -type f -name "my.cnf"
    
    /application/mysql-5.5.51/mysql-test/suite/rpl/my.cnf
    
    /application/mysql-5.5.51/mysql-test/suite/federated/my.cnf
    
    /application/mysql-5.5.51/mysql-5.5.51-linux2.6-x86_64/mysql-test/suite/rpl/my.cnf
    
    /application/mysql-5.5.51/mysql-5.5.51-linux2.6-x86_64/mysql-test/suite/federated/my.cnf
    
    /etc/my.cnf  ###(一般都是这里)
    

    1.4.1.1 修改

    [root@localhost log]# vim /etc/my.cnf

    找到 [mysqld] 下面添加

    slow_query_log =1
    
    slow_query_log_file=/application/mysql/data/localhost-slow.log
    
    long_query_time = 1
    

    参数说明:

    1. slow_query_log 慢查询开启状态  1 为开启
    2. slow_query_log_file 慢查询日志存放的位置
    3. long_query_time 查询超过多少秒才记录   默认10秒 修改为1秒

    修改完重启MySQL

    1.5 查看、测试

    1.5.1.1 插入一条测试慢查询

    mysql> select sleep(2);
    
    +----------+
    
    | sleep(2) |
    
    +----------+
    
    |    0 |
    
    +----------+
    
    1 row in set (2.00 sec)
    

    1.5.1.2 查看慢查询日志

    [root@localhost data]# cat /application/mysql/data/localhost-slow.log
    
    /application/mysql/bin/mysqld, Version: 5.5.51-log (MySQL Community Server (GPL)). started with:
    
    Tcp port: 3306 Unix socket: /tmp/mysql.sock
    
    Time         Id Command  Argument
    
    /application/mysql/bin/mysqld, Version: 5.5.51-log (MySQL Community Server (GPL)). started with:
    
    Tcp port: 3306 Unix socket: /tmp/mysql.sock
    
    Time         Id Command  Argument
    
    /application/mysql/bin/mysqld, Version: 5.5.51-log (MySQL Community Server (GPL)). started with:
    
    Tcp port: 3306 Unix socket: /tmp/mysql.sock
    
    Time         Id Command  Argument
    
    # Time: 170605 6:37:00
    
    # User@Host: root[root] @ localhost []
    
    # Query_time: 2.000835 Lock_time: 0.000000 Rows_sent: 1 Rows_examined: 0
    
    SET timestamp=1496615820;
    
    select sleep(2);
    

    1.5.1.3 通过MySQL命令查看有多少慢查询

    mysql> show global status like '%Slow_queries%';
    
    +---------------+-------+
    
    | Variable_name | Value |
    
    +---------------+-------+
    
    | Slow_queries | 1   |
    
    +---------------+-------+
    
    1 row in set (0.00 sec)
    
    

    1.6 日志分析工具mysqldumpslow

    在生产环境中,如果要手工分析日志,查找、分析SQL,显然是个体力活,MySQL提供了日志分析工具mysqldumpslow

    MySQL 慢查询日志分析

    mysql> show variables like '%slow%';
    +---------------------+-------------------------+
    | Variable_name       | Value                    |
    +---------------------+-------------------------+
    | log_slow_queries    | ON                        |
    | slow_launch_time    | 2                          |
    | slow_query_log      | ON                         |
    | slow_query_log_file | D:/log/slow.txt       |
    +---------------------+-------------------------+

    其中,各参数说明如下:

    slow_launch_time: 慢查询超过的执行时间值

     slow_query_log: 是否打开慢查询日志功能

    show_query_log_file:慢查询日志目录  

    开启慢查询日志功能:

    mysql配置文件(win mysql.ini linux mysql.conf)下,

    [mysqld]

    log-slow-queries ="D:/xampp/mysql/long.txt"
    long_query_time = 1

    log-slow-queries=/var/lib/mysql/slowquery.log (指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log)
    long_query_time=2 (记录超过的时间,默认为10s)
    log-queries-not-using-indexes (log下来没有使用索引的query,可以根据情况决定是否开启)
    log-long-format (如果设置了,所有没有使用索引的查询也将被记录)

    mysqldumpslow, mysql官方提供的慢查询日志分析工具. 输出图表如下:
    主要功能是, 统计不同慢sql的
    出现次数(Count), 
    执行最长时间(Time), 
    累计总耗费时间(Time), 
    等待锁的时间(Lock), 
    发送给客户端的行总数(Rows), 
    扫描的行总数(Rows), 
    用户以及sql语句本身(抽象了一下格式, 比如 limit 1, 20 用 limit N,N 表示).

    mysqlsla, hackmysql.com推出的一款日志分析工具(该网站还维护了 mysqlreport, mysqlidxchk 等比较实用的mysql工具)
    整体来说, 功能非常强大. 数据报表,非常有利于分析慢查询的原因, 包括执行频率, 数据量, 查询消耗等.

    格式说明如下:
    总查询次数 (queries total), 去重后的sql数量 (unique)
    输出报表的内容排序(sorted by)
    最重大的慢sql统计信息, 包括 平均执行时间, 等待锁时间, 结果行的总数, 扫描的行总数.

    Count, sql的执行次数及占总的slow log数量的百分比.
    Time, 执行时间, 包括总时间, 平均时间, 最小, 最大时间, 时间占到总慢sql时间的百分比.
    95% of Time, 去除最快和最慢的sql, 覆盖率占95%的sql的执行时间.
    Lock Time, 等待锁的时间.
    95% of Lock , 95%的慢sql等待锁时间.
    Rows sent, 结果行统计数量, 包括平均, 最小, 最大数量.
    Rows examined, 扫描的行数量.
    Database, 属于哪个数据库
    Users, 哪个用户,IP, 占到所有用户执行的sql百分比

    Query abstract, 抽象后的sql语句
    Query sample, sql语句

    除了以上的输出, 官方还提供了很多定制化参数, 是一款不可多得的好工具.

    mysql-explain-slow-log, 德国人写的一个perl脚本.
    http://www.willamowius.de/mysql-tools.html


    功能上有点瑕疵, 不仅把所有的 slow log 打印到屏幕上, 而且统计也只有数量而已. 不推荐使用.
    mysql-log-filter, google code上找到的一个分析工具.提供了 python 和 php 两种可执行的脚本.
    http://code.google.com/p/mysql-log-filter/
    功能上比官方的mysqldumpslow, 多了查询时间的统计信息(平均,最大, 累计), 其他功能都与 mysqldumpslow类似.
    特色功能除了统计信息外, 还针对输出内容做了排版和格式化, 保证整体输出的简洁. 喜欢简洁报表的朋友, 推荐使用一下.
    myprofi, 纯php写的一个开源分析工具.项目在 sourceforge 上.
    http://myprofi.sourceforge.net/

     
    功能上, 列出了总的慢查询次数和类型, 去重后的sql语句, 执行次数及其占总的slow log数量的百分比.
    从整体输出样式来看, 比mysql-log-filter还要简洁. 省去了很多不必要的内容. 对于只想看sql语句及执行次数的用户来说, 比较推荐.

    总结

    工具/功能一般统计信息高级统计信息脚本优势
    mysqldumpslow支持不支持perlmysql官方自带
    mysqlsla支持支持perl功能强大,数据报表齐全,定制化能力强.
    mysql-explain-slow-log支持不支持perl
    mysql-log-filter支持部分支持python or php不失功能的前提下,保持输出简洁
    myprofi支持不支持php非常精简
    【参考资料】
    1、MySQL 慢查询日志分析及可视化结果 – 运维生存时间 http://www.ttlsa.com/mysql/mysql-slow-query-log-analysis-and-visualization-of-results/
    2、Mysql 慢日志分析系统搭建 —— Box Anemometer_SleePerSir_新浪博客 http://blog.sina.com.cn/s/blog_c2839d2a0102wkuv.html
    3、mysql性能监控软件 慢日志分析利器 - pmm server https://blog.csdn.net/john1337/article/details/70855293

    4、MySQL 慢查询日志(Slow Query Log) - CSDN博客 https://blog.csdn.net/leshami/article/details/39829605

    5、关于MySQL 通用查询日志和慢查询日志分析 - CSDN博客 https://blog.csdn.net/timchen525/article/details/75268151

    6、mysql 慢日志分析工具pt-query-digest - CSDN博客 https://blog.csdn.net/stevendbaguo/article/details/47612359

    展开全文
  • 2.开启查询日志,设置阈值,比如超过5秒钟的就是SQL, 并将它抓取出来。 3.explain+SQL分析 4.show profile 5.运维经理orDBA,进行SQL数据库服务器的参数调优。 ==========总结========== 1.查询的开启并...

    查询优化分析过程

    =========分析==========
    1.观察,至少跑1天,看看生产的慢SQL情况。
    2.开启慢查询日志,设置阈值,比如超过5秒钟的就是慢SQL, 并将它抓取出来。
    3.explain+慢SQL分析
    4.show profile
    5.运维经理orDBA,进行SQL数据库服务器的参数调优。

    ==========总结==========
    1.慢查询的开启并捕获
    2.explain+慢SQL分析
    3.showprofile查询SQL在Mysql服务器里面的执行细节和生命周期情况
    4.SQL数据库服务器的参数调优。

    查询优化

    永远小表驱动大表。

    order by关键字优化

    ORDER BY子句,尽量使用 Index 方式排序,避免使用 filesort 方式排序

    尽可能在索引列上完成排序操作,遵照索引建的最佳左前缀

    MySQL支持二种方式的排序,filesort 和 Index, Index效率高。 它指MySQL扫描索引本身完成排序。FileSort方式效率较低。

    ORDER BY满足两情况,会使用Index方式排序

    • ORDER BY语句使用索引最左前列

    • 使用where子句与OrderBy子句条件列组合满足索引最左前列

    如果不在索引列上,filesort有两种算法:mysql就要启动双路排序和单路排序

    group by关键字优化

    groupby实质是先排序后进行分组,遵照索引建的最佳左前缀

    当无法使用索引列,增大max_length_for_sort_data参数的设置+增大sort_buffer_size参数的设置

    where高于having,能写在where限定的条件就不要去having限定了。

    慢查询日志

    • MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_ftime值 的SQL,则会被记录到慢查询日志中。

    • 具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询志中。long_query_time的默认值为10,意思是运行10秒以_上的语句。

    • 由他来查看哪些SQL超出了我们的最大忍耐时间值,比如一条sql执行超过5秒钟,我们就算慢SQL,希望能收集超过5秒的sq|,结合之前explain进行全面分析。

    使用方法

    默认情况下,MySQL数据库没有开启慢查询日志,需要我们手动来设置这个参数。

    当然,如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性能影响。慢查询日志支持将日志记录写入文件

    查看是否开启

    show VARIABLES LIKE '%slow_query_log%';

    默认情况下slow_query_log的值为OFF,表示慢查询日志是禁用的,可以通过设置slow_query_log的值来开启。

    开启

    使用set global slow_query_log=1开启了慢查询日志只对当前数据库生效,如果MySQL重启后则会失效。

    如果要永久生效,就必须修改配置文件my.cnf (其它系统变量也是如此) 修改my.cnf文件,[mysqld]下 增加或修改参数 slow_query_logslow_query_log_file后, 然后重启MySQL服务器。也即将如下两行配置进my.cnf文件

    slow_query_log=1
    slow_query_log_file=/arlib/mysq/localhost-slow.log

    关于慢查询的参数slow_ query_log_file ,它指定慢查询日志文件的存放路径,系统默认会给-一个缺省的文件host_name-slow.log (如果没有指定参数slow_ query_log_file的话)

    开启慢查询日志后,什么样的SQL参会记录到慢查询里面?

    这个是由参数long_query_time控制,默认情况下long_query_time的值为10秒, 命令

     SHOW VARIABLES LIKE 'long_query_time%';

     可以使用命令修改,也可以在my.cnf参数里面修改。 假如运行时间正好等于long_query_time的情况, 并不会被记录下来。也就是说,在mysql源码里是判断大于long_query_time; 而非大于等于。

    设置慢查询阈值

    set global long_query_time = n;

    模拟产生慢查询

    select sleep(4);

    查询系统慢查询数量

    show global status like '%Slow_queries%';

    查询系统慢查询数量

    show global status like '%Slow_queries%';

    日志分析工具

    在生产环境中,如果要手工分析日志,查找、分析SQL,显然是个体力活,MySQL提供了日志分析工具mysqldumpslow。

    mysqldumpslow --help

    s:是表示按何种方式排序
    c:访问次数
    l:锁定时间
    r:返回记录
    t:查询时间
    al:平均锁定时间
    ar:平均返回记录数
    at:平均查询时间
    t:即为返回前面多少条的数据
    g:后边搭配一个正则匹配模式,大小写不敏感的

    常用方式

    # 得到返回记录集最多的10个SQL
    mysqldumpslow -s r -t 10 /var/lib/mysql/localhost-slow.log
    # 得到访问次数最多的10个SQL
    mysqldumpslow -s C -t 10 /var/lib/mysql/localhost-slow.log
    # 得到按照时间排序的前10条里面含有左连接的查询语句
    mysqldumpslow -s t -t 10 -g "left join" /var/lib/mysql/localhost-slow.log
    # 另外建议在使用这些命令时结合|和more使用,否则有可能出现爆屏情况
    mysqldumpslow -s r -t 10 /var/lib/mysql/localhost-slow.log | more

    展开全文
  • mysqldumpslow是mysql自带的用来分析慢查询的工具,当然不止这一种工具,还有percona-toolkit是percona公司出的一组命令行工具的集合,用来执行各种通过手工执行非常复杂和麻烦的mysql相关任务,包含以下内容: ...
    

    mysqldumpslow是mysql自带的用来分析慢查询的工具,当然不止这一种工具,还有percona-toolkit是percona公司出的一组命令行工具的集合,用来执行各种通过手工执行非常复杂和麻烦的mysql相关任务,包含以下内容:

    检查master和slave数据一致性/记录有效的归档/服务器信息汇总/分析和统计日志,为了省事这块使用mysqldumpslow命令做分析。

    需要开启mysql的慢查询日志,否则无法进行统计分析,开启mysql慢查询日志需要在mysql的配置文件中进行如下配置:

    slow_query_log = 3#定义超过3秒的查询计数到变量Slow_queries
    slow-query-log-file = mysql-slow.log
    long_query_time = 1

    -s,是order的顺序

    al  平均锁定时间

    ar  平均返回记录时间

    at  平均查询时间(默认)

    c    计数

    l    锁定时间

    r    返回记录

    t    查询时间

    -t,是top n的意思,即为返回前面多少条的数据

    -g,后边可以写一个正则匹配模式,大小写不敏感的

    例:

    按照平均查询时间进行排序,同时取排序的前20个:

    以下面这条sql为例:

    mysqldumpslow -s at -t 20 mysql-slow.log

     Count: 1  Time=19.26s (19s)  Lock=0.00s (0s)  Rows=1000.0 (1000), kaifa[kaifa]@[10.10.254.2]
      select cou from (
      select count(*) as cou from `foot_step` where is_deleted=N group by user_id 
      ) c order by cou desc
      LIMIT N, N

    Count:sql出现的次数占slow_log的百分比:1次

    Time: sql执行到返回的时间长为:19s

    (19s):这条sql执行的总时间19s

    Lock:锁时间为0s

    Rows=1000.0:发送给客户端1000行

    (1000):总共扫描扫到1000行

    后面的是sql本身:账号、sql语句。

    优化建议:sql中已经含有limit取值段,可以再加点条件过滤更精确,如时间段。

    主要功能是, 统计不同慢sql的

    出现次数(Count),

    执行最长时间(Time),

    累计总耗费时间(Time),

    等待锁的时间(Lock),

    发送给客户端的行总数(Rows),

    扫描的行总数(Rows),

    用户以及sql语句本身(抽象了一下格式, 比如 limit 1, 20 用 limit N,N 表示).

    展开全文
  • mysql 查询页面工具

    2018-05-17 09:57:51
    mysql 慢查询页面工具 页面化分析慢日志
  • 1.在 windows 下可以在mysql/bin目录下可以找到 mysqldumpslow.pl 文件,是一个 perl 格式的文件; 这种格式的文件在windows下是不能直接执行的,若要使用,得先安装 perl 支持,我们可以在 Perl 的官网下载对应...

    1.在 windows 下可以在mysql/bin目录下可以找到 mysqldumpslow.pl 文件,是一个 perl 格式的文件;
    这种格式的文件在windows下是不能直接执行的,若要使用,得先安装 perl 支持,我们可以在 Perl 的官网下载对应平台的安装包:https://www.perl.org/get.html,为了使用方便,安装完成后最好配置环境变量。

    2.进入mysqldumpslow.pl 文件所在的存储目录,我的在D:\wamp64\bin\mysql\mysql5.7.14\bin,运行命令:perl mysqldumpslow.pl -h可看到运行结果,展示了一些选项的使用方法;

    3.接下来使用命令:

    mysql5.7.14\bin>perl mysqldumpslow.pl -t 3 ../data/mysql-slow.log |more

    -t 3表示只查询最新的三条数据,后面接慢查询日志所属路径,效果图如下:
    这里写图片描述

    展开全文
  • MySQL慢查询日志分析详解

    千次阅读 2019-06-27 12:59:56
    MySQL查询日志MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL,则会被记录到查询日志中。long_query_time的默认值为10,意思是运行10S...
  • 主要介绍MySQL数据库中查询日志的使用流程、使用方式、以及日志分析工具mysqldumpslow的相关内容
  • MySQL慢日志分析工具mysqlsla

    千次阅读 2013-07-11 18:14:36
    mysqlsla是一个分析mysql慢日志工具,由hackmysql.com推出,功能强大,可以分析出慢查询的原因,包括执行某条sql出现的次数及在slow log数据的百分比、执行时间、等待销的时间等。    如何安装 下载...
  • 5、MySQL慢日志分析工具(pt-query-digest) 1、介绍及作用 作为一名优秀的mysql dba也需要有掌握几个好用的mysql管理工具,所以我也一直在整理和查找一些能够便于管理mysql的利器。以后的一段时间内,将会花一大...
  • mysql 慢日志分析工具pt-query-digest

    千次阅读 2015-08-13 15:08:47
    之前windows下mysql5.6.20使用mysqldumpslow.pl分析慢日志,今天又看到一个工具pt-query-digest,原本打算在windows上安装使用,结果在windows上执行C:\Program Files\MySQL\MySQL Server 5.6\bin>pt-query-digest...
  • 最近做数据库优化, 查询日志实在太大, 需要找个分析工具统计一下结果, 结果发现搜出来的都是要执行perl脚本的, windows天生不支持... 好不容易下载了ActivePerl, 发现服务器操作系统(window server 2003)支持不...
  • MySQL慢日志简介及Anemometer工具介绍

    千次阅读 2019-02-01 17:51:47
    MySQL 慢日志简介: ...MySQL慢日志想必大家或多或少都有听说,主要是用来记录MySQL中长时间执行(超过long_query_time 单位秒),同时examine的行数超过min_examined_row_limit ,影响MySQL性能的SQL语句,以便D...
  • MySQL慢查询日志记录和分析

    千次阅读 2019-01-08 21:05:41
    一、引言 在日常的开发中,有时候会有用户反馈说网站的响应速度...这个时候,我们就需要慢慢分析,我们可以通过开启查询日志,来监控生产环境上有没有执行特别的SQL,如果有,我们可以定位到是哪一条SQL,从而...
  • mysql的slow_query_log查询日志分析工具说明,主要用来进行查询日志的linux平台分析输出结果文档进行MySQL的调优/优化数据库
  • MySQL自带一个perl的200多行的脚本名为mysqldumpslow,可对查询日志信息进行分析,使用非常便利,这篇文章对其使用进行介绍。
  • 介绍:Anemometer 是一个图形化显示MySQL慢日志工具。结合pt-query-digest,Anemometer可以很轻松的帮你去分析慢查询日志,让你很容易就能找到哪些SQL需要优化 This is the Box Anemometer, the MySQL Slow ...
  • Slowquery图形化显示MySQL慢日志工具在线演示:http://fander.asuscomm.com:8008/slowquery/slowquery.php背景:由于天兔Lepus慢查询工具是运行在PHP CI框架里,而不是作为一个独立的web页面接口,所以想直接接入...
  • 一个sql执行很的就叫sql,一般来说sql语句执行超过5s就能够算是sql,需要进行优化了 为何要对SQL进行治理 每一个SQL都需要消耗一定的I/O资源,SQL执行的快慢直接决定了资源被占用时间的长短。假设业务要求...
  • MySQL 日志分析工具

    2012-03-20 18:20:28
    数据报表,非常有利于分析慢查询的原因, 包括执行频率, 数据量, 查询消耗等. 格式说明如下: 总查询次数 (queries total), 去重后的sql数量 (unique) 输出报表的内容排序(sorted by) 最重大的sql统计信息, 包括 ...
  • MySQL 语句没有进行优化,数据库的读写耗费了大量的时间 可能访问的网页中存在调用远程(第三方)接口的业务,远程接口返回特别 大量的访问请求导致带宽撑满 服务器负载过大忙不过来,比如说 CPU 和内存消耗完了 ...
  • windows下mysql慢日志

    千次阅读 2019-06-18 21:17:07
    慢查日志是为了帮助我们分析...常用mysql慢日志工具有:mysqldumpslow和pt-query-digest,以及mysql本身提供的命令explain。 查看慢查询日志是否开启: SHOW VARIABLES LIKE '%slow%'; 各参数如下: sl...
  • 使用ELK分析Mysql慢查询日志

    千次阅读 2019-08-28 19:15:18
    4.Mysql慢查询配置 5.具体分析 6.参考资料 1.ELK介绍 1)Elasticsearch Elasticsearch 是基于 JSON 的分布式搜索和分析引擎,专为实现水平扩展、高可靠性和管理便捷性而设计。 Elasticsearch 是一个分布式的 ...
  • MySQL慢查询日志分析

    2018-07-17 12:48:51
    1、在MySQL中查找哪些查询是查询,可以开启查询日志,利用查询日志分析出哪条SQL语句比较。 2、查询日志支持动态开启。以下是配置查询日志的常用命令: ①mysql> set global slow-query-log=on...
  • 我们数据库上的慢日志是全部存在一个单独的文件中的,xxxxx-slow.log。要获取每天的slow log日志,就要用到sed提取出来: sed -n '/2020-08-13T00/,/2020-08-14T00:00/p' xxxxx-slow.log > 20200813.log ...
  • 在慢日志文件比较大的时候,用文件查看命令去分析MYSQL慢日志文件,看起来就会比较费劲,也不能快速的统计出需要优化的SQL语句。 使用mysqldumpslow就可以相对快速地进行筛选出需要优化的SQL语句,是手工进行数据库...
  • mysql慢查询日志

    2020-06-01 23:30:43
    MySQL查询日志MySQL提供的一种日志记录,它用来记录在MySQL中响应时间超过阀值的语句。具体怎么玩我们先看下面的演示。 二、查询日志配置 默认情况下slow_query_log的值为OFF,表示查询日志是禁用的。...
  • 主要介绍了对MySQL慢查询日志进行分析的基本教程,文中提到的Query-Digest-UI这个基于B/S的图形化查看工具非常好用,需要的朋友可以参考下
  • ELK收集MySQL慢日志

    千次阅读 2019-03-04 15:37:20
    ELK6.6.1+FileBeat6.6.1收集mysql慢日志 一、elk简单介绍 1、之前常说的elk,现已被官方整合为Elastic Stack,官网地址(https://www.elastic.co/cn/products),官网给出的架构如下,其中Beats是一系列轻量级日志...
  • 4、MySQL慢日志分析工具(mysqldumpslow) 1、介绍 如何进行查看慢查询日志,如果开启了慢查询日志,就会生成很多的数据,然后我们就可以通过对日志的分析,生成分析报表,然后通过报表进行优化。 2、用法 接下来...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 35,011
精华内容 14,004
关键字:

mysql慢日志分析工具

mysql 订阅