前言
最近在尝试一个日志系统graylog来收集mysql的慢查询日志提,供后续的分析、监控和报警等。测试步骤已经到日志已成功收集到graylog,测试时需要刷一些慢查询日志出来。为了刷比较多的日志和不对测试环境造成较大的影响,想到了使用mysql的sleep函数结合event来做刷慢日志。
MySQL的计划任务是通过event来完成的。相当于SQL Server 的Job。下面是实现过程:
打开mysql的慢日志
set global slow_query_log = 1; set global long_query_time = 1;
也可以在配置文件议开启慢日志(建议开启)
创建event
-
启用event事件功能。
set global event_scheduler = 1;
-
创建event,每1秒执行一次。
delimiter $$ create or replace EVENT event_flush_slow_log ON SCHEDULE EVERY 1 SECOND on completion preserve ENABLE do begin SELECT SLEEP(1); end; $$ delimiter ;
查询event
show events where Name like '%event_flush_slow_log%'G; 或 select * from information_schema.events where event_name='event_flush_slow_log'G;
-
开启这个event
ALTER EVENT event_flush_slow_log ENABLE;
可以看到慢日志一直在写入了。
# Time: 180126 12:19:57 # User@Host: root[root] @ localhost [localhost] # Thread_id: 1640 Schema: db1 QC_hit: No # Query_time: 1.000645 Lock_time: 0.000269 Rows_sent: 1 Rows_examined: 0 # Rows_affected: 0 SET timestamp=1516940397; SELECT SLEEP(1); # Time: 180126 12:19:58 # User@Host: root[root] @ localhost [localhost] # Thread_id: 1641 Schema: db1 QC_hit: No # Query_time: 1.000575 Lock_time: 0.000203 Rows_sent: 1 Rows_examined: 0 # Rows_affected: 0 SET timestamp=1516940398; SELECT SLEEP(1); # Time: 180126 12:19:59 # User@Host: root[root] @ localhost [localhost] # Thread_id: 1642 Schema: db1 QC_hit: No # Query_time: 1.000856 Lock_time: 0.000180 Rows_sent: 1 Rows_examined: 0 # Rows_affected: 0 SET timestamp=1516940399; SELECT SLEEP(1);
-
完成后,关闭event
ALTER EVENT event_flush_slow_log DISABLE;
-
假如不需要这个event,可以删除
DROP EVENT IF EXISTS event_flush_slow_log;
关于sleep函数和event的详细用法,请参考相关文档,这里不再展开。
定时刷慢日志也可以使用Linux crontab调用脚本来做,但每1秒都要登录一次MySQL来执行一次慢查询,消耗资源较大,不建议这样做吧。