`

如何记录mysql慢查询sql日志

 
阅读更多

修改my.cnf的mysqld部分:

long_query_time = 1              //定义慢查询的时间1表示1秒
--log-slow-queries[=file_name]   //记录慢查询到日志文件
--log-queries-not-using-indexes //将没使用索引的sql记录到日志文件
实例:
[mysqld]
long_query_time = 1
log-slow-queries = /usr/local/mysql5.0.40/var/slow_query.log
log-queries-not-using-indexes = true

"too many connections"找不到问题所在,后来发现打开mysql的慢查询会有很大的帮助就搞了一个.

打开MySQL慢查询
MySQL慢查询记录日志对于跟踪PHP+MySQL体系下的MySQL负载调优问题很有用处,比如安装了很多Discuz!插件的用户,这样可以大概排查出那些插件有代码问题。其实启用MySQL的慢查询日志很简单,只需要在MySQL的配置文件里添加log-slow-queries和long_query_time两个参数即可。

今天有个朋友问我,就顺带记录上来。更多的MySQL优化信息可以查看这里:http://www.ccvita.com/category/mysql

Windows下开启MySQL慢查询
MySQL在Windows系统中的配置文件一般是是my.ini找到[mysqld]下面加上
log-slow-queries = F:\MySQL\log\mysqlslowquery.log
long_query_time = 2

Linux下启用MySQL慢查询
MySQL在Windows系统中的配置文件一般是是my.cnf找到[mysqld]下面加上
log-slow-queries=/data/mysqldata/slowquery.log
long_query_time=2

注意
log-slow-queries = F:\MySQL\log\mysqlslowquery.log为查询日志存放的位置,一般这个目录要有MySQL的运行帐号的可写权限,一般都将这个目录设置为MySQL的数据存放目录;
long_query_time=2中的2表示查询超过两秒才记录;

启用 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

mysqldumpslow, mysql官方提供的慢查询日志分析工具. 输出图表如下

主要功能是, 统计不同慢sql的
出现次数(Count), 
执行最长时间(Time), 
累计总耗费时间(Time), 
等待锁的时间(Lock), 
发送给客户端的行总数(Rows), 
扫描的行总数(Rows), 
用户以及sql语句本身(抽象了一下格式, 比如 limit 1, 20 用 limit N,N 表示).

讲一下有用的参数: 
-s 排序选项:c 查询次数 r 返回记录行数 t 查询时间 
-t 只显示top n条查询 
mysqldumpslow -s r -t 10 slow.log 

 

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 支持 不支持 perl mysql官方自带
mysqlsla 支持 支持 perl 功能强大,数据报表齐全,定制化能力强.
mysql-explain-slow-log 支持 不支持 perl
mysql-log-filter 支持 部分支持 python or php 不失功能的前提下,保持输出简洁
myprofi 支持 不支持 php 非常精
分享到:
评论

相关推荐

    Mysql慢查询日志查看

    这将显示慢查询日志中,记录次数最多的 10 条 SQL 语句,并将结果保存到 f:\master-slow-0.txt 文件中。 mysqldumpslow 命令的选项包括: -s:按照何种方式排序,c、t、l、r 分别是按照记录次数、时间、查询时间、...

    mysql慢查询日志的使用

    MySQL慢查询日志是MySQL提供的一种日志记录方式,用于记录所有执行时间超过指定阈值(默认10秒)的SQL语句,帮助开发者和DBA定位数据库性能瓶颈,优化SQL查询效率。 #### 开启与配置 1. **开启慢查询日志:** - ...

    MySQL慢查询日志

    MySQL慢查询日志是一种重要的工具,用于记录执行时间超过预设阈值的SQL语句。通过对这些记录进行分析,可以找出数据库中的性能瓶颈,并据此采取相应的优化措施。 #### 二、慢查询日志的作用 1. **性能调优**:帮助...

    Mysql慢查询日志_1--如何开启慢查询日志

    MySQL 慢查询日志是 MySQL database management system 的一个重要功能,通过该功能可以记录执行时间超过某个阈值的 SQL 语句,从而帮助数据库管理员或开发人员对数据库的性能进行优化和改进。下面将详细介绍如何在 ...

    mysql的慢日志配置查询和show processlist使用

    通过分析慢查询日志,我们可以找到 MySQL 中执行时间最长的 SQL 语句,并对其进行优化,从而提高 MySQL 的性能。 在上面的例子中,我们手动触发了两个慢查询,一个是 11 秒的慢查询,另一个是 20 秒的慢查询。然后...

    mysql慢日志查询

    MySQL慢查询日志是一种重要的工具,用于记录执行时间超过指定阈值的SQL语句。这些记录可以帮助数据库管理员和开发人员识别并优化那些效率较低的查询,从而提高整体性能。 #### 二、慢查询日志的作用 1. **性能优化...

    MySQL优化篇:慢查询日志.pdf

    MySQL数据库中的慢查询日志是一种重要的诊断工具,它记录了数据库中执行时间超过预设阈值的SQL语句。这些语句可能会对数据库的性能造成影响,因此,通过分析慢查询日志,可以识别并优化这些语句,提升数据库的运行...

    mysql 慢查询页面工具

    总结来说,MySQL 慢查询页面工具 Query-Digest-UI 是一个基于 Percona Toolkit 的图形化监控解决方案,它帮助管理员可视化 MySQL 的慢查询日志,从而更有效地进行性能调优。通过安装和配置该工具,你可以实时监控...

    mysql慢日志分析工具mysqlsla

    在MySQL的运行过程中,某些SQL语句执行时间过长,就会被记录到慢查询日志中。通过分析这些慢查询日志,我们可以找到性能瓶颈并采取相应的优化措施。 `mysqlsla-2.03.tar.tar` 是MySQLsla的源代码包,你需要先解压...

    cpp-Slowquery图形化显示MySQL慢日志工具

    1. **MySQL慢查询日志**:MySQL数据库允许管理员开启慢查询日志,记录那些执行时间过长的SQL语句,有助于性能调优。 2. **C++编程**: Slowquery使用C++编写,这是一种强大的编程语言,能够提供高性能和低级别的内存...

    MySQL慢查询日志.docx

    MySQL的慢查询日志是数据库管理员用于识别和优化性能瓶颈的重要工具。它记录了执行时间超过预设阈值的SQL查询,帮助我们定位那些影响数据库性能的查询操作。通过分析这些慢查询,我们可以采取相应的优化策略,比如...

    线上慢查询日志文档及命令

    MySQL的慢查询日志记录了那些执行时间超过预设阈值的SQL语句,这有助于识别并优化那些影响系统性能的查询。默认情况下,慢查询日志是关闭的,需要手动开启。可以通过修改`my.cnf`或`my.ini`配置文件,在[mysqld]段落...

    Mysql慢查询日志

    **查询与设定慢查询记录数:** 可以通过`SHOW VARIABLES LIKE 'slow_query_log'`、`SHOW VARIABLES LIKE 'slow_query_log_file'`、`SHOW VARIABLES LIKE 'long_query_time'`以及`SHOW VARIABLES LIKE 'log_queries_...

    MySQL SQL查询优化最佳实践

    详细介绍慢查询日志及示例演示,MySQL查询优化器介绍及特定SQL的查询优化等 1.获取有性能问题的SQL的三种方法 2.慢查询日志概述 3.慢查询日志实例 4.实时获取性能问题SQL 5.SQL的解析预处理及生成的执行计划 6.如何...

    mysql开启查看慢查询日志借鉴.pdf

    总之,通过开启和分析MySQL的慢查询日志,我们可以有效地找出执行效率低下的SQL语句,从而对数据库进行优化,提高整体性能。记得在操作配置文件和日志文件时确保有适当的权限,以及定期清理和分析日志以保持系统健康...

    MySQL慢查询相关知识

    慢查询日志是MySQL用于记录所有执行时间超过特定阈值的SQL语句的功能。启用此功能可以帮助我们找到需要优化的查询。 ##### 1. 查看慢查询日志的配置 可以使用`SHOW VARIABLES`命令来查看慢查询日志的相关配置,...

    关于Mysql通用查询日志和慢查询日志分析

    慢查询日志则专门记录那些运行时间超过`long_query_time`秒的SQL查询。默认情况下,慢查询日志是关闭的,`long_query_time`默认为10秒。开启慢查询日志和查看当前设置,可以使用`SHOW VARIABLES LIKE '%slow_query%...

    慢sql监控mysql及oracle.pdf

    MySQL 的慢查询日志(Slow Query Log)是一种日志记录,用于记录在 MySQL 中响应时间超过阀值的语句。长查询时间的默认值为 10 秒,意思是运行时间超过 10 秒的语句将被记录到慢查询日志中。 启用慢查询日志需要...

Global site tag (gtag.js) - Google Analytics