Mysql应用MySQL Event Scheduler(事件调度器)

Mysql应用MySQL Event Scheduler(事件调度器),第1张

概述介绍《Mysql应用MySQL Event Scheduler(事件调度器)》开发教程,希望对您有用。

《MysqL应用MysqL Event Scheduler(事件调度器)》要点:
本文介绍了MysqL应用MysqL Event Scheduler(事件调度器),希望对您有用。如果有疑问,可以联系我们。

一、概述
  事件调度器是在 MysqL 5.1 中新增的另一个特色功能,可以作为定时任务调度器,取代部分原先只能用 *** 作系统任务调度器才能完成的定时功>能.例如,linux 中的 crontabe 只能精确到每分钟执行一次,而 MysqL 的事件调度器则可以实现每秒钟执行一个任务,这在一些对实时性要>求较高的环境下就非常实用了.
  事件调度器是定时触发执行的,在这个角度上也可以称作是"临时的触发器".触发器只是针对某个表产生的事件执行一些语句,而事件调度器则是在某一个(间隔)时间执行一些语句.事件是由一个特定的线程来管理的,也就是所谓的"事件调度器".启用事件调度器后,拥有 SUPER 权限的账户执行 SHOW PROCESSList 就可以看到这个线程了.通过设定全局变量event_scheduler 的值即可动态的控制事件调度器是否启用.
代码如下:
(root:localhost:)test> SET GLOBAL event_scheduler = ON;
(root:localhost:)test> show processList\G
*************************** 4. row ***************************
ID: 46147
User: event_scheduler
Host: localhost
db: NulL
Command: Daemon
Time: 1
State: Waiting on empty queue
Info: NulL

  如上,该线程的所有者是 event_scheduler.
  二、应用案例
  本案例是利用 event scheduler 的特性,每秒钟调用一次存储过程,用于判断 SLAVE 是否正常运行,如果发现 SLAVE 关闭了,忽略 0 次错误,然后重新启动 SLAVE.
  首先创建存储过程
delimiter //
代码如下:
create procedure `Slave_Monitor`()
begin
SELECT VARIABLE_VALUE INTO @SLAVE_STATUS
FROM information_schema.GLOBAL_STATUS
WHERE VARIABLE_name='SLAVE_RUNNING';
IF ('ON' != @SLAVE_STATUS) THEN
SET 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应用MySQL Event Scheduler(事件调度器)全部内容,希望文章能够帮你解决Mysql应用MySQL Event Scheduler(事件调度器)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1161408.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存