解决办法
故障总结
系统中的global read lock被其它线程获取了(被加上了S锁),因此DML在grl上面加IX锁时会出现Waiting for global read lock,而set read_only在grl上加的是S锁,因此此时是可以grant的,而此时系统中存在大查询,set global read_only=1需要等待表被关闭,因此状态是:Waiting for table flush
因此原因可以确定了:系统中存在flush tables with read lock但是没有unlock tables
小技巧
在手动做FLUSH TABLES WITH READ LOCK/set global read_only=1之前,先执行一下FLUSH TABLES,能够很大概率地减小系统变成只读的时间
参考
mysql出现大量FLUSH TABLES WITH READ LOCK
原文地址:http://kkkkkk.blog.51cto.com/468162/1655892