MySQL如何监控系统全部执行过的sql语句
概述
考虑这么一个场景,开发系统时有个模块执行很慢,但是又不知道这中间涉及到什么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';
1、查看是否开启日志记录
show variables like “general_log%” ;
![详解MySQL如何监控系统全部执行过的sql语句](http://www.isolves.com/d/file/p/2024/07-01/7a279bdf4ee7bf1788c5a47cc65d42bf.jpg)
2、临时开启日志记录
set global general_log='ON';
这时执行的所有sql都会被记录下来,但是如果重启mysql就会停止记录需要重新设置
![详解MySQL如何监控系统全部执行过的sql语句](http://www.isolves.com/d/file/p/2024/07-01/06ad010e8eaec3738e480bf7ba02a04b.jpg)
3、查看日志
# tail -f /usr/local/mysql/data/iZmfgnjkehk13uZ.log
![详解MySQL如何监控系统全部执行过的sql语句](http://www.isolves.com/d/file/p/2024/07-01/bcf1a65e701160595904b55c6747a7b6.jpg)
这里主要是介绍general_log这个参数,大家有空也可以测试一下。