磁盘空间满了之后MySQL会怎样
浏览:2702次 出处信息
导读
当磁盘空间爆满后,MySQL会发生什么事呢?又应该怎么应对?
会发生什么事
当磁盘空间写满了之后,MySQL是无法再写入任何数据的,包括对表数据的写入,以及binlog、binlog-index等文件。
当然了,因为InnoDB是可以把脏数据先放在内存里,所以不会立刻表现出来无法写入,除非开启了binlog,写入请求才会被阻塞。
当MySQL检测到磁盘空间满了,它会:
每分钟:检查空间是否得到释放,以便写入新数据。当发现有剩余空间了,就会继续写入数据,一切照旧。
每十分钟:如果还是发现没剩余空间,则会在日志中写入一条记录,报告磁盘空间满(这时候只写入几个字节还是够的)。
提高监控系统检测频率,预防再次发生;
及时删除不用的文件,释放空间;
若有线程因磁盘满的问题被阻塞了,可先杀掉,等到下一分钟重新检测时它可能又可以正常工作了;
可能因磁盘满导致某些线程被阻塞,引发其他线程也被阻塞,可把导致阻塞的线程杀掉,其他被阻塞的线程也就能继续工作了。
应该怎么办
那么,当发现磁盘空间满了之后,我们应该怎么处理呢,建议:
例外
有个例外的情况是:
当执行 REPAIR TABLE 或者 OPTIMIZE TABLE 操作时,或者执行完 LOAD DATA INFILE 或 ALTER TABLE 之后批量更新索引时,这些操作会创建临时文件,当执行这些操作过程中mysqld发现磁盘空间满了,就会把这个涉及到的表标记为crashed,删掉临时文件(除了 ALTER TABLE 操作,MySQL会放弃正在执行的操作,删除临时文件,释放磁盘空间)。
备注:当执行这些命令过程中mysqld进程被意外被杀掉的话,其所生成临时文件不会自动删除,需要手工删掉才能释放磁盘空间。
建议继续学习:
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:linux上二进制部署mysql详细步骤(测试环境常用)
文章信息
- 作者:叶金荣 来源: iMySQL
- 标签: 磁盘空间
- 发布时间:2015-11-08 23:00:10
建议继续学习
近3天十大热文
-
[58] memory prefetch浅析
-
[53] 转载:cassandra读写性能原理分析
-
[47] MySQL半同步存在的问题
-
[46] 深入浅出cassandra 4 数据一致性问
-
[41] javascript插入样式
-
[40] 《web前端最佳实践》—高维护性css
-
[39] 获取Dom元素的X/Y坐标
-
[37] MySQL vs NoSQL 效率与成本之争
-
[35] 不是书评 :《我是一只IT小小鸟》
-
[34] 基本排序算法的PHP实现