事件调度器是定时触发执行的,在这个角度上也可以称作是临时的触发器。触发器只是针对某个表产生的事件执行一些语句,而事件调度器则是在某一个(间隔)时间执行一些语句。事件是由一个特定的线程来管理的,也就是所谓的事件调度器。启用事件调度器后,拥有 super 权限的账户执行 show processlist 就可以看到这个线程了。通过设定全局变量event_scheduler 的值即可动态的控制事件调度器是否启用。
(root:localhost:)test> set global event_scheduler = on;(root:localhost:)test> show processlist\g*************************** 4. row ***************************id: 46147user: event_schedulerhost: localhostdb: nullcommand: daemontime: 1state: waiting on empty queueinfo: null
如上,该线程的所有者是 event_scheduler。
应用案例
本案例是利用 event scheduler 的特性,每秒钟调用一次存储过程,用于判断 slave 是否正常运行,如果发现 slave 关闭了,忽略 0 次错误,然后重新启动 slave。
首先创建存储过程
delimiter //create procedure `slave_monitor`()beginselect variable_value into @slave_status from information_schema.global_status where variable_name='slave_running';if ('on' != @slave_status) thenset global sql_slave_skip_counter=0;slave start;end if;end; //delimiter ;
由于存储过程中无法调用类似 show slave status 这样的语句,因此无法得到确切的复制错误信息和错误代码,不能进一步的处理 slave 停止的各种情况。
接着,创建任务
create event if not exists `slave_monitor`
on schedule every 5 second
on completion preserve
do
call slave_monitor();
创建了一个任务,每 5秒钟 执行一次,任务结束后依旧保留该任务,而不是删除。当然了,在本例中的任务不会结束,除非将它手动禁止了。
如果在运行中想要临时关闭一下某个任务,执行 alter event 语句即可:
(root:localhost:)test> alter event `slave_monitor` on
completion preserve disable;
(root:localhost:)test> alter event `slave_monitor` on
completion preserve enable;
以上就是mysql事件调度器event scheduler详解的内容。
