mysql慢查询日志对于跟踪有问题的查询非常有用,可以分析出当前程序里是否有很耗费资源的sql语句,这是一个有用的日志。它对于性能的影响不大(假设所有查询都很快),并且强调了那些最需要注意的查询(丢失了索引或索引没有得到最佳应用),那如何打开mysql的慢查询日志记录呢?

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

(1)配置开启

Linux:

在mysql配置文件 my.cnf 中增加如下语句:

log-slow-queries=/var/lib/mysql/slowquery.log #指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.loglong_query_time=5 #记录超过的时间,默认为10s,这里设置为查询时间超过5s的查询语句log-queries-not-using-indexes = on # 列出没有使用索引的查询语句#log-queries-not-using-indexes 是否记录所有没有使用索引的query,可以根据情况决定是否开启#log-long-format 是否记录所有的查询记录,包括没有使用索引的查询

在 my.ini 的[mysqld]添加如下语句(语句选项以及释义同上):

log-slow-queries = E:\mysql\log\mysqlslowquery.loglong_query_time = 5

Linux:

使用mysql自带命令mysqldumpslow查看

常用命令

  • -s ORDER what to sort by (t, at, l, al, r, ar etc), 'at' is default
  • -t NUM just show the top n queries
  • -g PATTERN grep: only consider stmts that include this string

eg:

-s,是order的顺序,说明写的不够详细,俺用下来,包括看了代码,主要有 c,t,l,r和ac,at,al,ar,分别是按照query次数,时间,lock的时间和返回的记录数来排序,前面加了a的时倒序

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

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

具体命令使用如下:

mysqldumpslow -s c -t 20 host-slow.logmysqldumpslow -s r -t 20 host-slow.log

mysqldumpslow -t 10 -s t -g “left join” host-slow.log这个是按照时间返回前10条里面含有左连接的sql语句。

Windows:

当你是第一次开启mysql的慢查询,会在你指定的目录下创建这个记录文件,本文就是mysqlslowquery.log,这个文件的内容大致如下(第一次开启MYSQL慢查询的情况下)

E:\web\mysql\bin\mysqld, Version: 5.4.3-beta-community-log (MySQL Community Server (GPL)). started with:
TCP Port: 3306, Named Pipe: (null)
Time Id Command Argument

可以通过如下的命令来查看慢查询的记录数:

mysql> show global status like ‘%slow%';+---------------------+-------+| Variable_name    | Value |+---------------------+-------+| Slow_launch_threads | 0   || Slow_queries    | 0   |+---------------------+-------+

1.执行一条慢查询SQL语句

mysql> select sleep(2);
ls /usr/local/mysql/data/slow.log

总结

更多相关文章

  1. ES6 变量声明,箭头函数,数组方法,解构赋值,JSON,类与继承,模块化练习
  2. 浅谈Java中Collections.sort对List排序的两种方法
  3. Python list sort方法的具体使用
  4. python list.sort()根据多个关键字排序的方法实现
  5. android上一些方法的区别和用法的注意事项
  6. android实现字体闪烁动画的方法
  7. Android中dispatchDraw分析
  8. Android四大基本组件介绍与生命周期
  9. [Android(安卓)NDK]Android(安卓)JNI开发例子 ---3 在JNI中实现o

随机推荐

  1. mysql无法登陆修复
  2. SQL主键的外键问题
  3. Amoeba实现mysql主从读写分离1
  4. 查询从wordnet mysql获取反义词?
  5. Mysql 命令行快速导入数据
  6. Qt通过ODBC连接SQL Server2008实践总结
  7. Oracle SQL Developer是一个与c#一起使用
  8. mysql中insert...select引发的死锁
  9. SQL对多个列分别进行合并的操作,100分送
  10. [置顶] SQL Server 日期相关