MySQL慢日志

慢查询日志顾名思义就是查询慢的sql语句可以记录到一个日志文件里,至于有多慢才会被记录,默认是10秒,但也可以通过系统配置来更改,慢日志在做系统优化时是一个非常好用的工具

sql 复制代码
#是否开启慢日志
show variables like 'slow_query_log';

#如果值为on说明已经开启,否则执行以下命令开启慢日志查询
set global slow_query_log = on

#查看一下慢查询日志文件的位置
show variables like 'slow_query_log_file';

#查询long_query_time的阈值,并修改指定的阈值
#ong_query_time既是一个全局变量又是一个会话变量,
#所以需要同时设置,若只设置全局,则需新建会话才能生效
show global variables like 'long_query_time';  #全局
show variables like 'long_query_time';    #会话
set global long_query_time = 1; #全局
set long_query_time = 1;    #会话

#查询当前慢查询SQL的数量
show status like 'slow_queries';

上面的操作只是对本次MySQL服务器有效,若服务器重启,则会失效。若想永久有效,需要修改MySQL的配置文件my.cnf

sql 复制代码
[mysqld]
slow_query_log=ON     #开启慢查询日志的开关
slow_query_log_file=/var/lib/mysql/localhost-slow.log    #慢查询日志的目录和文件名信息
long_query_time=3     #设置慢查询的阙值为3秒,超出此设定值的SQL即被记录到慢查询日志
log_output=FILE
相关推荐
迷茫运维路17 分钟前
MySQL5.7主从延迟高排查优化思路
数据库·主从延时高
菜鸟学Python1 小时前
Python web框架王者 Django 5.0发布:20周年了!
前端·数据库·python·django·sqlite
小云数据库服务专线1 小时前
GaussDB 查看会话连接数
数据库·gaussdb
墨迹的陌离2 小时前
【Linux】重生之从零开始学习运维之Mysql
linux·运维·服务器·数据库·学习·mysql
BigBigHang3 小时前
【docker】DM8达梦数据库的docker-compose以及一些启动踩坑
数据库·docker·容器
m0_720245014 小时前
QT(四)基本组件
数据库·qt·microsoft
Databend4 小时前
使用 Databend Cloud 归档 OceanBase 数据数据库
数据库
fei飛fei飞5 小时前
数据库事务中的陷阱:脏读、幻读与不可重复读
数据库
FINE!(正在努力!)5 小时前
关于sql面试积累
数据库·sql
看天走路吃雪糕5 小时前
墨者:SQL过滤字符后手工绕过漏洞测试(万能口令)
数据库·sql·sql注入·墨者学院·万能口令