Home >Database >Mysql Tutorial >[MySQL 5.1 体验]MySQL 事件调度器(Event Scheduler)

[MySQL 5.1 体验]MySQL 事件调度器(Event Scheduler)

WBOY
WBOYOriginal
2016-06-07 15:25:591003browse

作/译者:叶金荣(Email: ),来源:http://imysql.cn 一、概述 事件调度器是在 MySQL 5.1 中新增的另一个特色功能,可以作为定时任务调度器,取代部分原先只能用操作系统任务调度器才能完成的定时功能。例如,Linux 中的 crontabe 只能精确到每分钟执行一次

作/译者:叶金荣(Email: [MySQL 5.1 体验]MySQL 事件调度器(Event Scheduler)),来源:http://imysql.cn

一、概述

事件调度器是在 MySQL 5.1 中新增的另一个特色功能,可以作为定时任务调度器,取代部分原先只能用操作系统任务调度器才能完成的定时功>能。例如,Linux 中的 crontabe 只能精确到每分钟执行一次,而 MySQL 的事件调度器则可以实现每秒钟执行一个任务,这在一些对实时性要>求较高的环境下就非常实用了。

事件调度器是定时触发执行的,在这个角度上也可以称作是
"临时的触发器"。触发器只是针对某个表产生的事件执行一些语句,而事件调度器则是在某一个(间隔)时间执行一些语句。事件是由一个特定的
线程来管理的,也就是所谓的
"事件调度器"。启用事件调度器后,拥有 SUPER 权限的账户执行 SHOW PROCESSLIST 就可以看到这个线程了。通过设定全局变量
event_scheduler 的值即可动态的控制事件调度器是否启用。

(root:localhost:)test> SET GLOBAL event_scheduler = ON;<br>(root:localhost:)test> show processlist/G<br>*************************** 4. row ***************************<br>     Id: 46147<br>   User: event_scheduler<br>   Host: localhost<br>     db: NULL<br>Command: Daemon<br>   Time: 1<br>  State: Waiting on empty queue<br>   Info: NULL<br>

如上,该线程的所有者是 event_scheduler。

二、应用案例

本文不讨论详细的事件调度器的语法,具体的语法参考可以看MySQL手册 第20章。

本案例是利用 event scheduler 的特性,每秒钟调用一次存储过程,用于判断 SLAVE 是否正常运行,如果发现 SLAVE 关闭了,忽略 0 次错误,然后重新启动 SLAVE。

  • 首先创建存储过程
    delimiter //<br>create procedure `Slave_Monitor`()<br>begin<br><br>SELECT VARIABLE_VALUE INTO @SLAVE_STATUS <br>FROM information_schema.GLOBAL_STATUS <br>WHERE VARIABLE_NAME='SLAVE_RUNNING';<br><br>IF ('ON' != @SLAVE_STATUS) THEN<br> SET GLOBAL SQL_SLAVE_SKIP_COUNTER=0;<br> SLAVE START;<br>END IF;<br><br>end; //<br>delimiter ;<br>

    由于存储过程中无法调用类似 SHOW SLAVE STATUS 这样的语句,因此无法得到确切的复制错误信息和错误代码,不能进一步的处理 SLAVE 停止的各种情况。

  • 接着,创建任务
    CREATE EVENT IF NOT EXISTS `Slave_Monitor`<br>ON SCHEDULE EVERY 5 SECOND<br>ON COMPLETION PRESERVE<br>DO<br>CALL Slave_Monitor();<br>

    创建了一个任务,每 5秒钟 执行一次,任务结束后依旧保留该任务,而不是删除。当然了,在本例中的任务不会结束,除非将它手动禁止了。

    如果在运行中想要临时关闭一下某个任务,执行 ALTER EVENT 语句即可:

     <br>(root:localhost:)test> alter event `Slave_Monitor` ON <br>COMPLETION PRESERVE DISABLE;<br>(root:localhost:)test> alter event `Slave_Monitor` ON <br>COMPLETION PRESERVE ENABLE;<br>
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn