MYSQL开启慢查询日志实施
来源:互联网 发布:诊所管理系统源码 编辑:程序博客网 时间:2024/06/08 07:03
查看当前服务器是否开启慢查询:
1、快速办法,运行sql语句show VARIABLES like "%slow%"
2、直接去my.conf中查看。
my.conf中的配置(放在[mysqld]下的下方加入)
[mysqld]
log-slow-queries = /usr/local/mysql/var/slowquery.log
long_query_time = 1 #单位是秒
log-queries-not-using-indexes
使用sql语句来修改:不能按照my.conf中的项来修改的。修改通过"show VARIABLES like "%slow%" "
语句列出来的变量,运行如下sql:
set global log_slow_queries = ON;
set global slow_query_log = ON;
set global long_query_time=0.1; #设置大于0.1s的sql语句记录下来
慢查询日志文件的信息格式:
# Time: 130905 14:15:59 时间是2013年9月5日 14:15:59(前面部分容易看错哦,乍看以为是时间戳)
# User@Host: root[root] @ [183.239.28.174] 请求mysql服务器的客户端ip
# Query_time: 0.735883 Lock_time: 0.000078 Rows_sent: 262 Rows_examined: 262 这里表示执行用时多少秒,0.735883秒,1秒等于1000毫秒
SET timestamp=1378361759; 这目前我还不知道干嘛用的
show tables from `test_db`; 这个就是关键信息,指明了当时执行的是这条语句
设置毫秒级别与mysql版本的关系
很多网上资料显示,5.21之前的版本,在my.conf中的long_query_time最小只能设置为1(也就是最小1秒)。我自己歪打误撞,发现我通过其他方式可以实现。
"long_query_time = 0.1"这种方式我没试,因为数据库服务器在跑。需要重启。所以没试。我是通过全局变量设置实现慢日志查询记录的。
可以通过全局变量设置方式实现毫秒级别记录:
set global long_query_time = 0.01
我服务器上mysql版本为:5.1.60-log
我试过这种方式有效。
怎么测试自己的查询是否会被记录下来呢?
运行语句
select sleep(0.13);
我故意设置0.13秒延迟,然后这条语句按照预期(因为之前设置超过0.1秒)会被记录到日志文件中去。
- MYSQL开启慢查询日志实施
- MYSQL开启慢查询日志实施
- 开启MySQL慢查询日志
- mysql 开启慢查询日志
- 【mysql】开启慢查询日志
- mysql 开启慢查询日志
- 开启MySQL慢查询日志
- MYSQL开启慢查询日志
- 开启mysql慢查询日志
- mysql慢查询日志开启
- mysql开启慢查询日志
- MySQL开启慢查询日志
- MYSQL开启慢查询日志
- Mysql开启慢查询日志
- 开启mysql慢查询日志
- 开启mysql慢查询日志
- 开启mysql慢查询日志
- mysql开启慢查询日志
- Qt5.3.1 ubuntu14.0464bit QSqlDatabase: QMYSQL driver not loaded的解决方案 real solution
- C++上机实验1-2
- 创建对象的内存图解
- sql server2008 “不允许保存更改,,,”
- Android开发中用到的第三方框架汇总
- MYSQL开启慢查询日志实施
- 数据结构的学习一简单排序算法1
- Android自定义View基础篇(二)
- RecyclerView简单使用
- 在中国知网下载 PDF 格式的学位论文
- 网络 应用层协议
- 【盘点】2014年跨境进口型电商十大模式
- mysql服务器查询慢原因分析与解决方法小结
- hdoj 2018 母牛的故事 (递归)