网上一大堆都是你转载我、我转载你的,垃圾信息太多了,打开的N个所谓的大站上面都是抄袭的不知道某个大神在N年前写的东西
另外。。。大部分胎神在哪儿将win系统下如何如开。。。还是图形界面下。。。还有用管理工具的。。。
国内大神都在忙事业,其他都在忙着转载。。。
实践出真知,自己折腾
修改mysql配置文件
1 | vi /etc/my.cnf |
按i进入编辑模式
在[mysqld]末尾(注意不要添加到其他项的配置下了)增加以下配置
1 2 3 | log-slow-queries = /home/wwwlogs/mysql_slow_querys.log long_query_time = 5 log-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编辑模式
1 | :wq |
mysql重新加载配置文件
1 | /etc/init.d/mysql reload |
好了 等着mysql记录日志即可
1 | 注意:VPS或者服务器运行一段时间后,日志会记录下这段时间的查询记录,当记录足够时,需要注释掉上述参数,重新加载mysql配置,以免影响生产环境 |
过段时间看看记录情况
1 | cat /home/wwwlogs/mysql_slow_querys.log |
如果有记录说明成功,如果没有记录需要去调整long_query_time = 5的值,减小查询时间设置
————–如何使用mysqldumpslow工具对日志进行分析————–
使用命令查找mysqldumpslow工具路径
1 | find / -name mysqldumpslow |
我的查询返回路径为
1 | /usr/local/mysql/bin/mysqldumpslow |
访问次数最多的10条sql语句
1 | /usr/local/mysql/bin/mysqldumpslow -s c -t 10 /home/wwwlogs/mysql_slow_querys.log |
返回记录最多的20条sql语句
1 | /usr/local/mysql/bin/mysqldumpslow -s r -t 10 /home/wwwlogs/mysql_slow_querys.log |
按照时间返回前10条里面含有left join的sql语句
1 | /usr/local/mysql/bin/mysqldumpslow -t 10 -s t -g “left join” /home/wwwlogs/mysql_slow_querys.log |
使用命令查看mysqldumpslow参数说明
1 | /usr/local/mysql/bin/mysqldumpslow -help |
mysqldumpslow常用参数
1 2 3 4 | -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
评论0