加入收藏 | 设为首页 | 会员中心 | 我要投稿 大连站长网 (https://www.0411zz.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL慢查询日志启动分析详解介绍

发布时间:2022-06-29 09:47:11 所属栏目:MySql教程 来源:互联网
导读:mysql的慢查询日志是用来记录log下来运行的比较慢的sql语句,默认是没有这个log的,为了开启这个功能,要修改my.cnf或者在MySQL启动的时候加入一些参数即可实现了,下面小编来整理windows与linux下的例子. 1)配置开启 Linux:在mysql配置文件 my.cnf 中增
  mysql的慢查询日志是用来记录log下来运行的比较慢的sql语句,默认是没有这个log的,为了开启这个功能,要修改my.cnf或者在MySQL启动的时候加入一些参数即可实现了,下面小编来整理windows与linux下的例子.
 
  1)配置开启
 
  Linux:在mysql配置文件 my.cnf 中增加如下语句:
 
  log-slow-queries=/var/lib/mysql/slowquery.log #指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log
 
  long_query_time=5 #记录超过的时间,默认为10s,这里设置为查询时间超过5s的查询语句
 
  log-queries-not-using-indexes = on # 列出没有使用索引的查询语句
 
  #log-queries-not-using-indexes 是否记录所有没有使用索引的query,可以根据情况决定是否开启
 
  #log-long-format 是否记录所有的查询记录,包括没有使用索引的查询.
 
  Windows:在 my.ini 的[mysqld]添加如下语句(语句选项以及释义同上):
 
  log-slow-queries = E:\mysql\log\mysqlslowquery.log
 
  long_query_time = 5
 
  2)查看方式
 
  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.log
 
  mysqldumpslow -s r -t 20 host-slow.log
 
  上述命令可以看出访问次数最多的20个sql语句和返回记录集最多的20个sql。
 
  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 |
  +———————+——-+
  生成了日志我们可以使用mysqlsla慢查询日志分析工具来进行处理具体看例子.
 
  一、mysqlsla的安装
 
  wget http://hackmysql.com/scripts/mysqlsla-2.03.tar.gz
  tar zvxf mysqlsla-2.03.tar.gz     
  cd mysqlsla-2.03   
  perl Makefile.PL   
  make  
  make install  
  二、使用参数说明
 
  1.--log-type (-lt) type logs:
 
  通过这个参数来制定log的类型,主要有slow,general,binary,msl,udl,分析slow log时通过制定为slow.
 
  2.--sort:
 
  制定使用什么参数来对分析结果进行排序,默认是按照t_sum来进行排序.
 
  t_sum按总时间排序,c_sum按总次数排序
 
  3.--top:
 
  显示sql的数量,默认是10,表示取按规则排序的前多少条.
 
  4.--statement-filter (-sf) [+-][TYPE]:
 
  过滤sql语句的类型,比如select、update、drop. [TYPE]有SELECT,CREATE,DROP,UPDATE, INSERT,例如"+SELECT,INSERT",不出现的默认是-,即不包括.
 
  5.--databases db:    
 
  要处理哪个库的日志:

  三、使用范例
 
  1.统计慢查询文件为dowload_server1-slow.log的所有select的慢查询sql,并显示执行时间最长的10条sql,并写到sql_time.sql中去
 
  mysqlsla -lt slow  -sf "+select" -top 10  dowload_server1-slow.log >test_time.log
 
  2.统计慢查询文件为dowload_server1-slow.log的数据库为ultraxsmutf8的所有select和update的慢查询sql,并查询次数最多的100条sql,并写到sql_num.sql中去
 
  mysqlsla -lt slow  -sf "+select,update" -top 100 -sort c_sum -db  ultraxsmutf8 dowload_server1-slow.log >num_time.log --phpfensi.com
 
  四、FAQ
 
  1.错误:
 
  Can't locate DBI.pm in @INC (@INC contains: /usr/lib/perl5/site_perl/5.8.8/i386-linux-thread-…….
 
  解决办法: perl -MCPAN -e 'install DBI' 或者cpan DBI
 
  2、错误:
 
  Use of uninitialized value in numeric comparison (<=>) at /usr/bin/mysqlsla line 2962.
 
  解决办法:当采用-sort t_su就会出现这个错误,默认就是采用时间排序,因此可以去掉.
 
  删除慢查询日志,直接通过命令 rm -f 删除了慢查询日志.
 

 

(编辑:大连站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!