码迷,mamicode.com
首页 > 数据库 > 详细

mysql出现大量FLUSH TABLES WITH READ LOCK

时间:2015-05-28 14:18:54      阅读:149      评论:0      收藏:0      [点我收藏+]

标签:mysql   所表   


解决办法

故障总结

系统中的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,能够很大概率地减小系统变成只读的时间


参考

http://www.gpfeng.com/?p=222


mysql出现大量FLUSH TABLES WITH READ LOCK

标签:mysql   所表   

原文地址:http://kkkkkk.blog.51cto.com/468162/1655892

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!