Error number: MY-010805; Symbol: ER_EVENT_CANT_GET_LOCK_FOR_DROPPING_EVENT; SQLSTATE: HY000
Message: Unable to obtain lock for dropping event %s from schema %s
错误说明
MY-010805,ER_EVENT_CANT_GET_LOCK_FOR_DROPPING_EVENT,以及SQLSTATE:HY000 错误意味着MySQL在尝试丢弃/删除现有的事件时无法获取锁,有可能是由于系统正在尝试丢弃某个事件,而不得不等待另一个线程完成正在进行的操作才能获得锁。
常见案例
该错误可能出现在你尝试丢弃一个事件而另一个线程正在使用此事件上的锁的情况下。这可能是有另一个进程正在执行一个 SHOW EVENTS 语句,而没有释放其所获得的锁。
解决方法
1.解决该问题的最简单方法是等待其他线程完成使用并释放事件锁,如果它们没有释放锁,就必须强制关闭它们。
2.如果你必须解决该问题,可以使用 KILL 连接来手动中断连接:
KILL conn_id
其中 conn_id 是持有事件锁的连接 ID,可以在 information_schema.processlist 内查看。
3.如果你正在使用MySQL集群,请确保你的cluster nodes上有足够的内存可用于MySQL操作。
4.另外,MySQL的官方文档中也建议更改线程等待模式:
设置锁取得等待超时为0,将避免系统长期停滞。可以在my.cnf中设置locked_in_memory参数,来防止MySQL产生太多的闲置线程(比如,locked_in_memory = 0)。
5.另一个可能的解决方法是,使用SET操作符为MySQL定义一个新的wait_timeout参数,设置的值不会超过允许的最大值,如:
SET GLOBAL wait_timeout = 60;
这将设置该系统的等待超时来处理未完成的事务或操作,让MySQL尝试丢弃该事件的请求。