mysql数据库什么情况下会锁表_记一次处理mysql数据库无故锁表的经历

某日,生产环境上的用户表突然无故锁表,原以为只是偶发的bug。所以第一时间想到的解决方案简单粗暴:重启数据库(service mysqld restart)。问题得以解决。

10min后,该表再次锁表。终于意识到问题并没有那么简单。

经过多方查资料,各种尝试。比如kill进程等方法,均无效。

最终看到一个,有可能是因为磁盘空间不足的原因,瞬间感觉就是它了。

df -h查看服务器磁盘占用情况,果然used已经100%了(没有做磁盘空间占用预警^-^!!)。

只能删除大文件了,一般tomcat的logs目录下的catalina.out文件都特别大。

一查,果然已经有15个G之多了。rm -f catalina.out 删除文件。

再用df -h查看磁盘占用情况。并没有任何改变。

经多方查证发现:删除正在使用中的文件时,系统不会立即释放文件所占空间。

此时可通过:

1、重启(生产环境重启,万一起不来呢。况且还是大晚上在家加班,起不来还得连夜处理。直接pass)

2、kill掉删除文件的进程

lsof |grep deleted    查找删除文件的进程(第二列是进程id,最后一列是删除文件的路径)

kill -9 进程id  (删除对应的进程)

再次df -h查看磁盘占用情况,磁盘空间已释放。

另外,锁表的问题还导致,主从同步停止。

重置主从同步,参考另一篇文章链接

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值