考虑这么一个场景,开发系统时有个模块执行很慢,但是又不知道这中间涉及到什么sql,就可以设想在没什么业务量的时候来监控数据库全部执行过的sql语句,方便排查问题。
1、开启general log模式
MySQL>set global general_log=on;
2、关闭general log模式
mysql>set global general_log=off;
3、设置log文件路径
mysql>set global general_log_file='xx/xx/xx.log';
show variables like “general_log%” ;
set global general_log='ON';
这时执行的所有sql都会被记录下来,但是如果重启mysql就会停止记录需要重新设置
# tail -f /usr/local/mysql/data/iZmfgnjkehk13uZ.log
这里主要是介绍general_log这个参数,大家有空也可以测试一下。