前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >linux系统Mysql5.5如何开启慢查询并分析数据?

linux系统Mysql5.5如何开启慢查询并分析数据?

原创
作者头像
用户7639835
修改2021-08-27 11:35:59
5960
修改2021-08-27 11:35:59
举报
文章被收录于专栏:技术知识分享

修改mysql配置文件

代码语言:javascript
复制
vi /etc/my.cnf

按i进入编辑模式 在[mysqld]末尾(注意不要添加到其他项的配置下了)增加以下配置

代码语言:javascript
复制
log-slow-queries = /home/wwwlogs/mysql_slow_querys.loglong_query_time = 5log-queries-not-using-indexes

说明: long_query_time 是指执行超过多久的sql会被log下来,上面参数5代表5秒 log-slow-queries是日志存放路径,自定义一个位置放日志,我用的lnmp一键包,为了方便日志统一管理,可以用/home/wwwlogs/mysql_slow_querys.log log-queries-not-using-indexes如果运行的SQL语句没有使用索引,则mysql数据库同样会将这条SQL语句记录到慢查询日志文件中

然后保存并退出vi编辑模式

代码语言:javascript
复制
:wq

mysql重新加载配置文件

代码语言:javascript
复制
/etc/init.d/mysql reload

好了 等着mysql记录日志即可

注意:VPS或者服务器运行一段时间后,日志会记录下这段时间的查询记录,当记录足够时,需要注释掉上述参数,重新加载mysql配置,以免影响生产环境

过段时间看看记录情况

代码语言:javascript
复制
cat /home/wwwlogs/mysql_slow_querys.log

如果有记录说明成功,如果没有记录需要去调整long_query_time = 5的值,减小查询时间设置

--------------如何使用mysqldumpslow工具对日志进行分析--------------

使用命令查找mysqldumpslow工具路径

代码语言:javascript
复制
find / -name mysqldumpslow

我的查询返回路径为

代码语言:javascript
复制
/usr/local/mysql/bin/mysqldumpslow

访问次数最多的10条sql语句

代码语言:javascript
复制
/usr/local/mysql/bin/mysqldumpslow -s c -t 10 /home/wwwlogs/mysql_slow_querys.log

返回记录最多的20条sql语句

代码语言:javascript
复制
/usr/local/mysql/bin/mysqldumpslow -s r -t 10 /home/wwwlogs/mysql_slow_querys.log

按照时间返回前10条里面含有left join的sql语句

代码语言:javascript
复制
/usr/local/mysql/bin/mysqldumpslow -t 10 -s t -g “left join” /home/wwwlogs/mysql_slow_querys.log

使用命令查看mysqldumpslow参数说明

代码语言:javascript
复制
/usr/local/mysql/bin/mysqldumpslow -help

mysqldumpslow常用参数

代码语言:javascript
复制
-s,是order的顺序,说明写的不够详细,主要有
c,t,l,r和ac,at,al,ar,分别是按照query次数,时间,lock的时间和返回的记录数来排序,前面加了a的时倒序
-t,是top n的意思,即为返回前面多少条的数据
-g,后边可以写一个正则匹配模式,大小写不敏感的

mysqldumpslow完整参数说明如下:

--verbose verbose

--debug debug

--help write this text to standard output

-v verbose

-d debug

-s ORDER what to sort by (al, at, ar, c, l, r, t), 'at' is default

al: average lock time

ar: average rows sent

at: average query time

c: count

l: lock time

r: rows sent

t: query time

-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

-g PATTERN grep: only consider stmts that include this string

-h HOSTNAME hostname of db server for *-slow.log filename (can be wildcard),

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档