MySQL Event Scheduler(事件调度器)
程序员文章站
2023-12-15 21:09:28
一、概述 事件调度器是在 mysql 5.1 中新增的另一个特色功能,可以作为定时任务调度器,取代部分原先只能用操作系统任务调度器才能完成的定时功>能。例如,li...
一、概述
事件调度器是在 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 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;