IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:Database Maintenance

共 1 篇相关文章

IT 累计浏览 3,554

磁盘空间满了之后MySQL会怎样

当数据库磁盘被撑爆后,MySQL会如何反应?这篇讲的正是这个运维中常见的“车祸现场”。磁盘满后,MySQL将无法写入任何新数据,包括表数据和binlog。不过,由于InnoDB可以先将脏页存放在内存,所以问题不会立刻爆发,只有在涉及binlog写入时,请求才会被阻塞。 文章详细描述了MySQL的后续行为:它会每分钟检查一次磁盘空间,一旦发现可用空间就立即恢复写入;如果连续十分钟仍无空间,则会在日志中记录一条告警。对于处理办法,作者给出了几个具体步骤:及时清理无用文件释放空间;若发现有线程被阻塞,可将其杀掉,等待系统下一轮自动检测后恢复正常;有时一个被阻塞的线程会引发连锁阻塞,处理掉源头线程即可解除整个卡顿。 此外,文章还特别提到了一个例外情况:在执行`REPAIR TABLE`、`OPTIMIZE TABLE`或批量更新索引等操作时,如果磁盘满了,MySQL会将涉及的表标记为崩溃状态并删除临时文件(`ALTER TABLE`操作则会主动放弃并清理)。需要注意的是,若此时mysqld进程意外终止,这些临时文件需要人工删除才能释放空间。整篇文章从现象到原理,再到实操应对,提供了清晰的排查与处理思路。