一,为什么要开启这个查询呢?
数据库是很容易产生瓶颈的地方,现在Nosql大家讨论这么热,估计都被数据库搞郁闷了。mysql中最影响速度的就是那些查询非常慢的语句,这些慢的语句,可能是写的不够合理或者是大数据下多表的联合查询等等,所以我们要找出这些语句,分析原因,加以优化。这也是发这篇博文的原因
二,开启mysql的慢查询
方法1,用命令开启慢查询
- mysql> show variables like "%long%";
- +-----------------+-----------+
- | Variable_name | Value |
- +-----------------+-----------+
- | long_query_time | 10.000000 |
- +-----------------+-----------+
- 1 row in set (0.00 sec)
-
- mysql> set global long_query_time=2;
- Query OK, 0 rows affected (0.00 sec)
-
- mysql> show variables like "%slow%";
- +---------------------+---------------------------------+
- | Variable_name | Value |
- +---------------------+---------------------------------+
- | log_slow_queries | OFF |
- | slow_launch_time | 2 |
- | slow_query_log | OFF |
- | slow_query_log_file | /usr/local/mysql/mysql-slow.log |
- +---------------------+---------------------------------+
- 4 rows in set (0.00 sec)
-
- mysql> set slow_query_log='ON';
- ERROR 1229 (HY000): Variable 'slow_query_log' is a GLOBAL variable and should be set with SET GLOBAL
- mysql> set global slow_query_log='ON';
- Query OK, 0 rows affected (0.28 sec)
-
- mysql> show variables like "%slow%";
- +---------------------+---------------------------------+
- | Variable_name | Value |
- +---------------------+---------------------------------+
- | log_slow_queries | ON |
- | slow_launch_time | 2 |
- | slow_query_log | ON |
- | slow_query_log_file | /usr/local/mysql/mysql-slow.log |
- +---------------------+---------------------------------+
- 4 rows in set (0.00 sec)
方法2,修改mysql的配置文件my.cnf
在[mysqld]里面加上以下内容
- long_query_time = 2
- log-slow-queries = /usr/local/mysql/mysql-slow.log
重起一下
/usr/local/mysql/libexec/mysqld restart
三,分析工具
分析工具干什么事的呢,其实就是把mysql-slow.log里面记录下来的数据,分析一下显示出来。其实自己写一个shell脚本也是可以把要的信息取出来的。我们来看一下mysql-slow.log里面到底是什么东西
- [root@BlackGhost mysql]# cat mysql-slow.log
- /usr/local/mysql/libexec/mysqld, Version: 5.1.26-rc-log (Source distribution). started with:
- Tcp port: 3306 Unix socket: /tmp/mysql.sock
- Time Id Command Argument
- # Time: 100814 13:28:30
- # User@Host: root[root] @ localhost []
- # Query_time: 10.096500 Lock_time: 0.045791 Rows_sent: 1 Rows_examined: 2374192
- SET timestamp=1281763710;
- 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);
- # Time: 100814 13:37:02
- # User@Host: root[root] @ localhost []
- # Query_time: 10.394134 Lock_time: 0.000091 Rows_sent: 1 Rows_examined: 2374192
- SET timestamp=1281764222;
- 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);
- # Time: 100814 13:37:16
- # User@Host: root[root] @ localhost []
- # Query_time: 4.608920 Lock_time: 0.000078 Rows_sent: 1 Rows_examined: 1260544
- SET timestamp=1281764236;
- 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的使用方法。
- [root@BlackGhost bin]# mysqldumpslow -h
- Option h requires an argument
- ERROR: bad option
-
- Usage: mysqldumpslow [ OPTS... ] [ LOGS... ]
-
- Parse and summarize the MySQL slow query log. Options are
-
- --verbose verbose
- --debug debug
- --help write this text to standard output
-
- -v verbose
- -d debug
- -s ORDER what to sort by (t, at, l, al, r, ar etc), 'at' is default
- -r reverse the sort order (largest last instead of first)
- -t NUM just show the top n queries
- -a don't abstract all numbers to N and strings to 'S'
- -n NUM abstract numbers with at least n digits within names //抽象的数字,至 少有n位内的名称
- -g PATTERN grep: only consider stmts that include this string //配置模式
- -h HOSTNAME hostname of db server for *-slow.log filename (can be wildcard), //mysql所以机器名或者IP
- default is '*', i.e. match all
- -i NAME name of server instance (if using mysql.server startup script)
- -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
分享到:
相关推荐
下面将详细介绍如何在 Windows 和 Linux 平台下开启 MySQL 慢查询日志。 一、Windows 平台下开启 MySQL 慢查询日志 在 Windows 平台下,MySQL 的配置文件通常命名为 my.ini。在这个文件中,我们可以添加以下配置项...
MySQL慢查询日志是一种重要的工具,用于记录执行时间超过预设阈值的SQL语句。通过对这些记录进行分析,可以找出数据库中的性能瓶颈,并据此采取相应的优化措施。 #### 二、慢查询日志的作用 1. **性能调优**:帮助...
1. **性能优化**:通过分析慢查询日志中的信息,可以找出性能瓶颈,并针对性地优化查询语句或调整数据库结构。 2. **监控与审计**:对于生产环境而言,慢查询日志还能够帮助监控数据库性能的变化趋势,并作为安全...
3. **慢查询日志**:开启慢查询日志,找出运行时间较长的SQL语句。 4. **状态与进程**:`SHOW STATUS`、`SHOW PROCESSLIST`、`SHOW ENGINE INNODB STATUS`揭示数据库运行状态和问题。 5. **工具辅助**:使用`...
3. 监控与日志:开启日志功能,定期分析MySQL慢查询日志,监控系统性能。 通过上述内容的学习,你将能掌握在Linux环境下MySQL的基本操作,进一步深入学习可以涉及复制、分区、存储引擎等高级主题,以满足更复杂的...
MySQL的日志系统包括错误日志、慢查询日志、二进制日志等,它们对于问题排查和审计至关重要。 12. **高可用性与复制** MySQL支持主从复制,实现数据冗余和故障切换,提高系统可用性。配置复制涉及设置服务器ID、...
### 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是一项常见的数据库安装任务,本文档详细介绍了整个安装过程以及对MySQL的一些基本配置。内容主要涉及了如何通过Yum包管理器安装MySQL服务器,配置MySQL服务开机自启动,设置MySQL用户...
通过分析这些慢查询,我们可以采取相应的优化策略,比如改进索引、调整查询语句或者优化数据表结构。 在MySQL中,开启慢查询日志可以通过修改配置文件实现。在Windows系统中,配置文件通常是`my.ini`,而在Linux...
总之,通过开启和分析MySQL的慢查询日志,我们可以有效地找出执行效率低下的SQL语句,从而对数据库进行优化,提高整体性能。记得在操作配置文件和日志文件时确保有适当的权限,以及定期清理和分析日志以保持系统健康...
分析慢查询日志时,通常会使用MySQL提供的`mysqldumpslow`工具。这个工具可以对日志进行解析和总结,帮助你快速找出问题查询。`mysqldumpslow`提供了多种排序选项(如`-s t`按时间,`-s l`按锁定时间等)和筛选选项...
使用mysql自带的工具mysqldumpslow可以分析慢查询日志。mysqldumpslow命令的基本用法如下: - mysqldumpslow -s t -t 20 /path/to/slowquery.log // 显示查询时间最长的20条慢查询日志记录 - mysqldumpslow -s c -t...
- 打开MySQL的配置文件`/etc/my.cnf`(或根据实际情况选择对应的配置文件路径)。 - 在`[mysqld]`段落中加入以下配置项: ```ini lower_case_table_names = 1 ``` - 保存并关闭文件。 - 重启MySQL服务以使...
在Linux环境下安装MySQL是许多初学者需要掌握的基本技能。MySQL是一种流行的关系型数据库管理系统,广泛应用于网站开发和数据存储。以下是在RHEL 5 (64位英文版)上安装和配置MySQL的详细步骤。 首先,你需要下载...
在这个主题中,"linux环境下mysql存储过程开启定时任务,bing log.rar" 文件可能包含了关于如何在Linux系统中利用MySQL的存储过程创建定时任务,以及如何记录和分析这些任务日志(bing log)的详细步骤。 首先,让...
总之,MySQL的慢查询功能是数据库性能优化的重要组成部分,合理使用和分析慢查询日志可以帮助我们发现和解决性能问题,提升系统整体运行效率。在日常运维中,定期检查和优化慢查询是非常必要的实践。
- 使用文本编辑器(这里使用`vim`)打开MySQL配置文件`/etc/my.cnf`。 - 在配置文件中加入一行`skip-grant-tables`以绕过权限表校验,便于重置root密码。 ##### 10. 重启MySQL服务 ```sh service mysqld restart ...
3. **日志记录**:开启慢查询日志和错误日志,有助于监控和优化数据库性能。 使用MySQL 5.5时,你可能需要了解以下命令行工具: 1. **mysql客户端**:连接数据库,执行SQL语句。 2. **mysqldump**:用于备份数据库...