MySQL-状态Waiting on empty queue引申
时间:2021-07-01 10:21:17
帮助过:510人阅读
(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。
二、MySQL 事件调度器的应用案例
本案例是利用 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 事件调度器(Event Scheduler) 的介绍,望你能有所收获
原文blog:http://www.codesky.net/article/201006/147600.html
MySQL-状态Waiting on empty queue引申
标签:示例 不能 val blog count empty ssl show tin