本文作者:kris

磁盘已满造成的mysql启动失败问题分享-mysql磁盘满了,无法启动

kris 2025-01-20 17:24:06 3
磁盘已满造成的mysql启动失败问题分享-mysql磁盘满了,无法启动摘要: MYSQL所在机器磁盘满了以后,写入数据库会阻塞吗?当磁盘空间写满了之后,MySQL是无法再写入任何数据的,包括对表数据的写入,以及binlog、binlog-index等文件。当...

MYSQL所在机器磁盘满了以后,写入数据库会阻塞吗?

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

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

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

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

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

应该怎么办

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

磁盘已满造成的mysql启动失败问题分享-mysql磁盘满了,无法启动

图片来源:网络

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

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

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

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

例外

有个例外的情况是:

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

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

mysql的binlog太大太多占用大量磁盘的解决?

今天有个同事来问我,说mysql目录下有很多1.1G的mysql-bin.00000*文件,占用了100多G,占用磁盘空间非常大,这些文件都是msyql日志文件,从几m到几个G都有可通,要解决这个问题并不难,只要修改/etc/my.cnf文件里的#log-bin=mysql-bin和#binlog_format=mixed把这二行注释掉,重启数据库就可以了!

mysql安装一定要装在c盘吗?

不一定。

它只是默认放在c盘,我们自己可以更改路径。若放C盘,一是会与操作系统竞争磁盘读写性能,会相对的降低mysql性能;二是会与操作系统竞争C盘空间,在C盘空间紧凑的情况下,C盘空间告警显示红色

mysql安装在c盘了怎么换到别的盘?

mysql安装在C盘之后,要想换到别的盘,可以卸载后重新安装。

另外一种方法,你可以不用重新安装,而单纯把数据库存储到其他的盘里面,这样一般不会显著的占用C盘的空间。如果是专门的数据库服务器,不少人是把数据库安装在一个独立的分区。

哪位朋友用过SSD固态硬盘,存mysql表速度提升明显么?

试过,自用笔记本是只有一个固态硬盘,同样的mysql版本和建表语句和索引。利用LOADDATAlocalINFILE'fileName'INTOTABLE表名;插入60万数据,固态硬盘大概4秒钟。回家用台式机,机械硬盘,则大概需要28秒,中间的差距还是很明显的。

文章版权及转载声明

作者:kris本文地址:https://www.damoyx.com/p/25260.html发布于 2025-01-20 17:24:06
文章转载或复制请以超链接形式并注明出处大漠游侠网

阅读
分享