IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

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

    OurMySQL发表于 2015-11-08 23:00:18
    love 0

    导读

    当磁盘空间爆满后,MySQL会发生什么事呢?又应该怎么应对?

    会发生什么事

    当磁盘空间写满了之后,MySQL是无法再写入任何数据的,包括对表数据的写入,以及binlog、binlog-index等文件。

    当然了,因为InnoDB是可以把脏数据先放在内存里,所以不会立刻表现出来无法写入,除非开启了binlog,写入请求才会被阻塞。

    当MySQL检测到磁盘空间满了,它会:

    • 每分钟:检查空间是否得到释放,以便写入新数据。当发现有剩余空间了,就会继续写入数据,一切照旧。

    • 每十分钟:如果还是发现没剩余空间,则会在日志中写入一条记录,报告磁盘空间满(这时候只写入几个字节还是够的)。

    • 应该怎么办

      那么,当发现磁盘空间满了之后,我们应该怎么处理呢,建议:

    • 提高监控系统检测频率,预防再次发生;

    • 及时删除不用的文件,释放空间;

    • 若有线程因磁盘满的问题被阻塞了,可先杀掉,等到下一分钟重新检测时它可能又可以正常工作了;

    • 可能因磁盘满导致某些线程被阻塞,引发其他线程也被阻塞,可把导致阻塞的线程杀掉,其他被阻塞的线程也就能继续工作了。

    例外

    有个例外的情况是:

    当执行 REPAIR TABLE 或者 OPTIMIZE TABLE 操作时,或者执行完 LOAD DATA INFILE 或 ALTER TABLE 之后批量更新索引时,这些操作会创建临时文件,当执行这些操作过程中mysqld发现磁盘空间满了,就会把这个涉及到的表标记为crashed,删掉临时文件(除了 ALTER TABLE 操作,MySQL会放弃正在执行的操作,删除临时文件,释放磁盘空间)。

    备注:当执行这些命令过程中mysqld进程被意外被杀掉的话,其所生成临时文件不会自动删除,需要手工删掉才能释放磁盘空间。

    抱歉猜想失败,您看看下面的文章有用吗?

    • 2009 年 9 月 21 日 -- mysql 中show 命令用法简介
    • 2008 年 12 月 12 日 -- MySQL DISTINCT 的基本实现原理
    • 2013 年 3 月 5 日 -- MySQL源码:Range优化相关的数据结构
    • 2012 年 2 月 22 日 -- MyISAM和InnoDB的不同优化
    • 2009 年 2 月 7 日 -- MySQL 1067错误解决方法集合
    • 2009 年 1 月 23 日 -- mysql limit查询优化
    • 2012 年 11 月 19 日 -- 关于MySQL变量innodb_rollback_on_timeout一些讨论
    • 2010 年 12 月 14 日 -- Handler-Socket Plugin for MySQL – SQL的功能、NoSQL的性能
    • 2008 年 12 月 18 日 -- InnoDB数据表空间文件平滑迁移
    • 2015 年 1 月 12 日 -- 注意sql语句中的通配符,别掉坑里面!


沪ICP备19023445号-2号
友情链接