`

linux下开启mysql慢查询,分析查询语句

 
阅读更多
一,为什么要开启这个查询呢?

数据库是很容易产生瓶颈的地方,现在Nosql大家讨论这么热,估计都被数据库搞郁闷了。mysql中最影响速度的就是那些查询非常慢的语句,这些慢的语句,可能是写的不够合理或者是大数据下多表的联合查询等等,所以我们要找出这些语句,分析原因,加以优化。这也是发这篇博文的原因

二,开启mysql的慢查询

方法1,用命令开启慢查询

  1. mysql> show variables like "%long%";         //查看一下默认为慢查询的时间10秒  
  2. +-----------------+-----------+  
  3. | Variable_name   | Value     |  
  4. +-----------------+-----------+  
  5. | long_query_time | 10.000000 |  
  6. +-----------------+-----------+  
  7. 1 row in set (0.00 sec)  
  8.   
  9. mysql> set global long_query_time=2;          //设置成2秒,加上global,下次进mysql已然生效  
  10. Query OK, 0 rows affected (0.00 sec)  
  11.   
  12. mysql> show variables like "%slow%";          //查看一下慢查询是不是已经开启  
  13. +---------------------+---------------------------------+  
  14. | Variable_name       | Value                           |  
  15. +---------------------+---------------------------------+  
  16. | log_slow_queries    | OFF                             |  
  17. | slow_launch_time    | 2                               |  
  18. | slow_query_log      | OFF                             |  
  19. | slow_query_log_file | /usr/local/mysql/mysql-slow.log |  
  20. +---------------------+---------------------------------+  
  21. 4 rows in set (0.00 sec)  
  22.   
  23. mysql> set slow_query_log='ON';                        //加上global,不然会报错的。  
  24. ERROR 1229 (HY000): Variable 'slow_query_log' is a GLOBAL variable and should be set with SET GLOBAL  
  25. mysql> set global slow_query_log='ON';            //启用慢查询  
  26. Query OK, 0 rows affected (0.28 sec)  
  27.   
  28. mysql> show variables like "%slow%";              //查看是否已经开启  
  29. +---------------------+---------------------------------+  
  30. | Variable_name       | Value                           |  
  31. +---------------------+---------------------------------+  
  32. | log_slow_queries    | ON                              |  
  33. | slow_launch_time    | 2                               |  
  34. | slow_query_log      | ON                              |  
  35. | slow_query_log_file | /usr/local/mysql/mysql-slow.log |  
  36. +---------------------+---------------------------------+  
  37. 4 rows in set (0.00 sec)  

方法2,修改mysql的配置文件my.cnf

在[mysqld]里面加上以下内容

  1. long_query_time = 2  
  2. log-slow-queries = /usr/local/mysql/mysql-slow.log  

重起一下
/usr/local/mysql/libexec/mysqld restart

三,分析工具

分析工具干什么事的呢,其实就是把mysql-slow.log里面记录下来的数据,分析一下显示出来。其实自己写一个shell脚本也是可以把要的信息取出来的。我们来看一下mysql-slow.log里面到底是什么东西

  1. [root@BlackGhost mysql]# cat mysql-slow.log     //查看命令  
  2. /usr/local/mysql/libexec/mysqld, Version: 5.1.26-rc-log (Source distribution). started with:  
  3. Tcp port: 3306  Unix socket: /tmp/mysql.sock  
  4. Time                 Id Command    Argument  
  5. # Time: 100814 13:28:30  
  6. # User@Host: root[root] @ localhost []  
  7. # Query_time: 10.096500  Lock_time: 0.045791 Rows_sent: 1  Rows_examined: 2374192  
  8. SET timestamp=1281763710;  
  9. select count(distinct ad_code) as x from ad_visit_history where ad_code in (select ad_code from ad_list where media_id=15);  
  10. # Time: 100814 13:37:02  
  11. # User@Host: root[root] @ localhost []  
  12. # Query_time: 10.394134  Lock_time: 0.000091 Rows_sent: 1  Rows_examined: 2374192  
  13. SET timestamp=1281764222;  
  14. select count(distinct ad_code) as x from ad_visit_history where ad_code in (select ad_code from ad_list where media_id=15);  
  15. # Time: 100814 13:37:16  
  16. # User@Host: root[root] @ localhost []  
  17. # Query_time: 4.608920  Lock_time: 0.000078 Rows_sent: 1  Rows_examined: 1260544  
  18. SET timestamp=1281764236;  
  19. select count(*) as cou  from ad_visit_history where ad_code in (select ad_code from ad_list where id=41) order by id desc;  

看到了,就是记录一下sql语句的执行情况,包括执行时间,锁定时间等,所以要不要分析工具看个人情况,分析工具很多,在这儿只说一下mysql慢查询分析工具mysqldumpslow的使用方法。

  1. [root@BlackGhost bin]# mysqldumpslow -h  
  2. Option h requires an argument  
  3. ERROR: bad option  
  4.   
  5. Usage: mysqldumpslow [ OPTS... ] [ LOGS... ]  
  6.   
  7. Parse and summarize the MySQL slow query log. Options are  
  8.   
  9.  --verbose    verbose  
  10.  --debug      debug  
  11.  --help       write this text to standard output  
  12.   
  13.  -v           verbose  
  14.  -d           debug          //查错  
  15.  -s ORDER     what to sort by (t, at, l, al, r, ar etc), 'at' is default     //排序方式query次数,时间,lock的时间和返回的记录数来排序  
  16.  -r           reverse the sort order (largest last instead of first)       //倒排序  
  17.  -t NUM       just show the top n queries                                       //显示前N多个  
  18.  -a           don't abstract all numbers to N and strings to 'S' 
  19.  -n NUM       abstract numbers with at least n digits within names   //抽象的数字,至 少有n位内的名称 
  20.  -g PATTERN   grep: only consider stmts that include this string      //配置模式 
  21.  -h HOSTNAME  hostname of db server for *-slow.log filename (can be wildcard),     //mysql所以机器名或者IP 
  22.  default is '*', i.e. match all 
  23.  -i NAME      name of server instance (if using mysql.server startup script) 
  24.  -l           don't subtract lock time from total time           //总时间中不减去锁定时间  

例子:

[root@BlackGhost bin]# ./mysqldumpslow -s r -t 20 /usr/local/mysql/mysql-slow.log

[root@BlackGhost bin]# ./mysqldumpslow -s r -t 20 -g 'count' /usr/local/mysql/mysql-slow.log

分享到:
评论

相关推荐

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

    下面将详细介绍如何在 Windows 和 Linux 平台下开启 MySQL 慢查询日志。 一、Windows 平台下开启 MySQL 慢查询日志 在 Windows 平台下,MySQL 的配置文件通常命名为 my.ini。在这个文件中,我们可以添加以下配置项...

    MySQL慢查询日志

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

    mysql慢日志查询

    1. **性能优化**:通过分析慢查询日志中的信息,可以找出性能瓶颈,并针对性地优化查询语句或调整数据库结构。 2. **监控与审计**:对于生产环境而言,慢查询日志还能够帮助监控数据库性能的变化趋势,并作为安全...

    Linux下的MySQL调优.ppt

    3. **慢查询日志**:开启慢查询日志,找出运行时间较长的SQL语句。 4. **状态与进程**:`SHOW STATUS`、`SHOW PROCESSLIST`、`SHOW ENGINE INNODB STATUS`揭示数据库运行状态和问题。 5. **工具辅助**:使用`...

    Linux下mysql学习笔记

    3. 监控与日志:开启日志功能,定期分析MySQL慢查询日志,监控系统性能。 通过上述内容的学习,你将能掌握在Linux环境下MySQL的基本操作,进一步深入学习可以涉及复制、分区、存储引擎等高级主题,以满足更复杂的...

    Linux下MySQL开发

    MySQL的日志系统包括错误日志、慢查询日志、二进制日志等,它们对于问题排查和审计至关重要。 12. **高可用性与复制** MySQL支持主从复制,实现数据冗余和故障切换,提高系统可用性。配置复制涉及设置服务器ID、...

    Linux下Mysql的配置

    ### Linux下MySQL的配置详解 #### 一、安装MySQL 在Linux系统中安装MySQL可以通过RPM包进行。这里提供了一个示例命令: ```bash rpm -ivh MySQL-server-4.1.22-0.glibc23.i386.rpm --nodeps rpm -ivh MySQL-...

    linux环境 yum安装mysql.pdf

    Linux环境下使用Yum安装MySQL是一项常见的数据库安装任务,本文档详细介绍了整个安装过程以及对MySQL的一些基本配置。内容主要涉及了如何通过Yum包管理器安装MySQL服务器,配置MySQL服务开机自启动,设置MySQL用户...

    MySQL慢查询日志.docx

    通过分析这些慢查询,我们可以采取相应的优化策略,比如改进索引、调整查询语句或者优化数据表结构。 在MySQL中,开启慢查询日志可以通过修改配置文件实现。在Windows系统中,配置文件通常是`my.ini`,而在Linux...

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

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

    mysql 开启慢查询 如何打开mysql的慢查询日志记录

    分析慢查询日志时,通常会使用MySQL提供的`mysqldumpslow`工具。这个工具可以对日志进行解析和总结,帮助你快速找出问题查询。`mysqldumpslow`提供了多种排序选项(如`-s t`按时间,`-s l`按锁定时间等)和筛选选项...

    MySQL开启慢查询日志功能的方法

    使用mysql自带的工具mysqldumpslow可以分析慢查询日志。mysqldumpslow命令的基本用法如下: - mysqldumpslow -s t -t 20 /path/to/slowquery.log // 显示查询时间最长的20条慢查询日志记录 - mysqldumpslow -s c -t...

    linux mysql中的坑

    - 打开MySQL的配置文件`/etc/my.cnf`(或根据实际情况选择对应的配置文件路径)。 - 在`[mysqld]`段落中加入以下配置项: ```ini lower_case_table_names = 1 ``` - 保存并关闭文件。 - 重启MySQL服务以使...

    linux下装mysql

    在Linux环境下安装MySQL是许多初学者需要掌握的基本技能。MySQL是一种流行的关系型数据库管理系统,广泛应用于网站开发和数据存储。以下是在RHEL 5 (64位英文版)上安装和配置MySQL的详细步骤。 首先,你需要下载...

    linux环境下mysql存储过程开启定时任务,bing log.rar

    在这个主题中,"linux环境下mysql存储过程开启定时任务,bing log.rar" 文件可能包含了关于如何在Linux系统中利用MySQL的存储过程创建定时任务,以及如何记录和分析这些任务日志(bing log)的详细步骤。 首先,让...

    Mysql开启慢查询

    总之,MySQL的慢查询功能是数据库性能优化的重要组成部分,合理使用和分析慢查询日志可以帮助我们发现和解决性能问题,提升系统整体运行效率。在日常运维中,定期检查和优化慢查询是非常必要的实践。

    linux安装mysql文档

    - 使用文本编辑器(这里使用`vim`)打开MySQL配置文件`/etc/my.cnf`。 - 在配置文件中加入一行`skip-grant-tables`以绕过权限表校验,便于重置root密码。 ##### 10. 重启MySQL服务 ```sh service mysqld restart ...

    mysql5.5 linux版

    3. **日志记录**:开启慢查询日志和错误日志,有助于监控和优化数据库性能。 使用MySQL 5.5时,你可能需要了解以下命令行工具: 1. **mysql客户端**:连接数据库,执行SQL语句。 2. **mysqldump**:用于备份数据库...

Global site tag (gtag.js) - Google Analytics