热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

根据mysql慢日志监控SQL语句执行效率

根据mysql慢日志监控SQL语句执行效率启用MySQL的log-slow-queries(慢查询记录)。在Linux环境下先要找到my.cnf文件(一般在/etc/mysql/),然后可能会发现该文件修改后无法保存,原因是你没有相应的权限,可以从属...SyntaxHighli

根据mysql慢日志监控SQL语句执行效率
 
启用MySQL的log-slow-queries(慢查询记录)。
 
  在Linux环境下先要找到my.cnf文件(一般在/etc/mysql/),然后可能会发现该文件修改后无法保存,原因是你没有相应的权限,可以从属性中看到该文件的所有者是root,这时要先以root的身份打开它:  www.2cto.com  
 
  sudo nautilus /etc/mysql
 
  接着再打开my.cnf文件然后找到[mysqld]标签在下面加上:
 
  log-slow-queries=/path/slow.log  –慢日志保存路径,该文件自己新建
  long_query_time=2                     –超过2秒的查询
  log-queries-not-using-indexes –记录没有使用索引的查询
 
保存,关闭。然后如果重启MySQL的话会碰到这样的提示:world-writable config file ‘ etc my.cnf’ is ignored
 
这时需要你再运行这个代码:
 
chmod 644 /etc/my.cnf       –644表示rw-r–r–
 
然后再重启服务就OK了。
 
但是要注意的是:log-slow-queries=/path/slow.log为慢查询日志存放的地方,而这个目录要有MySQL的运行帐号的可写权限,一般都将这个目录设置为MySQL的数据存放目录。
 
我是这么做的:先用root用户进到MySQL的数据存放目录(一般是/var/lib/mysql),新建一个slow.log文件(root用户能保证有权限新建,再运行chmod 644)。然后更改该文件的所有者和所在组:
 
  chown mysql运行帐户的名字(可以看同文件夹中其他文件的所有者和组)+小数点+组名(方法同用户名) /path/slow.log
 
或者:
 
  chown mysql运行帐户的名字(可以看同文件夹中其他文件的所有者和组)  /path/slow.log
 
  chgrp 组名(方法同用户名) /path/slow.log
 
这样才能保证MySQL能往slow.log中写日志。
 

推荐阅读
author-avatar
上当受骗的家_908
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有