您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
三六零分类信息网 > 马鞍山分类信息网,免费分类信息发布

MySQL Event Scheduler(事件调度器)

2025/7/10 2:37:25发布22次查看
事件调度器是在 mysql 5.1 中新增的另一个特色功能,可以作为定时任务调度器,取代部分原先只能用操作系统任务调度器才能完成的定时功能。
一、概述
事件调度器是在 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;
马鞍山分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product