MySQL之事件调度器介绍
MySQL5.1.6版本中引入了一项新特性EVENT,顾名思义就是事件、定时任务机制,在指定的时间单元内执行特定的任务,因此今后一些对数据定时性操作不再依赖外部程序,而直接使用数据库本身提供的功能。
其实MySQL的EVENT 功能和linux下的的at、crontab或Windows下的Task Scheduler计划任务类似。 也被称为MySQL事件调度器(Event Scheduler),可以在某一个时间点执行一个SQL语句或一个语句块(BEGIN … END);或者每隔固定间隔重复执行
一. 开启MySQL event_scheduler
要查看当前是否已开启事件调度器,可执行如下SQL:
SHOW VARIABLES LIKE ‘event_scheduler’;
或
SELECT @@event_scheduler;
或
SHOW PROCESSLIST;
若显示:
±----------------±------+
| Variable_name | Value |
±----------------±------+
| event_scheduler | OFF |
±----------------±------+
则可执行
SET GLOBAL event_scheduler = 1;
或
SET GLOBAL event_scheduler = ON;
来开启,也可以直接在启动命令加上“–event_scheduler=1”,例如:
mysqld … --event_scheduler=1
my.ini or my.cnf 中的
[mysqld]
添加 event_scheduler=ON
二.event的信息查询和含义
查看创建event语句:
查看某个event的状态信息,可查看mysql.event或者information_schema.events,或者简单地切到当前DB后执行show events; 三者的内容基本一致,information_schema无法做了下数据复制,更改了下列名称和starts时间以便更好的阅读。这里已information_schema.events里的信息为例解释
相关参数介绍:
三.使用建议
重要的事情 说3遍:注意!注意!注意!
- 如果是设定事件计划为0 或OFF,即关闭事件计划进程的时候,不会有新的事件执行,但现有的正在运行的事件会执行到完毕。
- 对于线上环境来说,使用event时,注意在主库上开启定时器,从库上上务必要关闭定时器,event触发所有操作均会记录binlog进行主从同步,从库上开启定时器很可能造成卡库。切换主库后之后记得将新主库上的定时器打开。
3.创建,删除等操作严禁直接操作mysql.event表,而是通过create等正规语法实现,不然会导致元数据混乱,各种莫名其妙的问题随之产生,比如event不执行或者重复执行。这时一般只有重启DB才能解决 了。
4.创建的event涉及到海量数据变更的话,要做好充分测试,确保不影响现网服务
5.如果需要备份带有event的DB,mysqldump时需要加上–event参数
6.参数event_scheduler为事件调度器的总开关,一般来说设置为ON或者OFF就好,不建议设置成disabled,如果设置为ON,show processlist可看到该线程