MySQL事件调度器Event Scheduler详解

php中文网
发布: 2016-06-07 16:07:07
原创
1292人浏览过

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

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

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

@@######@@

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

应用案例

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

首先创建存储过程

@@######@@
 
由于存储过程中无法调用类似 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:昨天的"玩具"到今天的竞争者
  • MySQL将会继续让LAMP架构发扬光大吗?
【责任编辑:碧海蓝天 TEL:(010)68476606】

1

<p>(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 </p>

登录后复制

1

<p>delimiter //<br>create procedure `Slave_Monitor`()<br>begin</p><p>SELECT VARIABLE_VALUE INTO @SLAVE_STATUS <br>FROM information_schema.GLOBAL_STATUS <br>WHERE VARIABLE_NAME='SLAVE_RUNNING';</p><p>IF ('ON' != @SLAVE_STATUS) THEN<br>SET GLOBAL SQL_SLAVE_SKIP_COUNTER=0;<br>SLAVE START;<br>END IF;</p><p>end; //<br>delimiter ;<br></p>

登录后复制
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号