mysql 磁盘已满_记一次 mysql 磁盘满解决过程

本文介绍了解决MySQL磁盘空间不足的问题,包括通过删除表、优化表结构、清理碎片等手段释放空间的方法,以及数据库备份与还原的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题:

使用命令发现磁盘使用率为 100% 了,还剩几十兆。

一系列神操作

备份数据库,删除实例、删除数据库表、重启 mysql 服务.结果磁盘空间均为释放

怎么办

网上查了很多资源,说要进行磁盘碎片化整理。原因是 datafree 占据的空间太多啦。具体可以通过这个 sql 查看。

SELECT CONCAT(TRUNCATE(SUM(data_length)/1024/1024,2),'MB') AS data_size,

CONCAT(TRUNCATE(SUM(max_data_length)/1024/1024,2),'MB') AS max_data_size,

CONCAT(TRUNCATE(SUM(data_free)/1024/1024,2),'MB') AS data_free,

CONCAT(TRUNCATE(SUM(index_length)/1024/1024,2),'MB') AS index_size

FROM information_schema.tables WHERE TABLE_NAME = 'datainfo';

这个是后来的图了,之前的图没有留,当时显示一张表里的 data_free 都达到了 20 个 G。

25cf461c6790ddcd8c497de80d858203.png

网上推荐的做法如下所示,对表格进行碎片化整理。

ALTER TABLE datainfo ENGINE=InnoDB;

ANALYZE TABLE datainfo;

optimize table datainfo;

僵局:

查看数据库版本为 5.562 不支持 inodb,要么选择升级数据库。正在这时,有个不好的消息发生了,那张表格给删掉了,但是磁盘空间还是没有释放啊。所以对表进行碎片化整理的路也走不通了,因为表没了。。。

后来的神操作

1、使用命令查看 mysql 安装的位置和配置文件所在的地方

mysql 1118 945 0 14:28 ? 00:00:00 /usr/sbin/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib64/mysql/plugin --log-error=/var/log/mysqld.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/lib/mysql/mysql.sock

2、关闭 mysql

service mysql stop

3、删除 datadir 目录下的 ibdata1、ib_logfile0 ib_logfile1 这些文件

fbfed399f2e119680236f4835f25fc84.png

4、 移动 mysql 的启动参数

mv /etc/my.cnf ./abc

5、重新启动 mysql 发现磁盘空间释放了

service mysql start

磁盘空间终于释放了

下一步数据库还原

1、采用 navicate 备份工具,进行数据库备份

8d4a0764af8393abdafc919a9c309b6d.png

备份成功后生成了,生成 psc 文件。

200409141055.psc

2、新建一个数据库实例,设置数据库名和字符集

2e72ec6d69d07c0a25eff3abed16bf87.png

3、然后对备份数据库进行还原,点击还原

e1cef4f695b4d3250ead9b601b9da55d.png

4、开始进行还原

第一次还原后发现还原后数据库表建成功了,但是表里面没有数据。

后来网上查找资料发现是,遇到错误就停止了。所以更改了还原的配置,再次进行还原。

之前是这样设置的

f9d60180b5eaa2aacac93a18ae39d09d.png

还原时当成一个事务进行了,遇到错误就停止了。

更改配置

b5861c4d3c277787f2c4ecf88f4467be.png

重新进行还原,数据库里的数据有了,并且验证没有问题。

问题解决

mysql 碎片化产生的原因

(1)表的存储会出现碎片化,每当删除了一行内容,该段空间就会变为被留空,而在一段时间内的大量删除操作,会使这种留空的空间变得比存储列表内容所使用的空间更大;

(2)当执行插入操作时,MySQL 会尝试使用空白空间,但如果某个空白空间一直没有被大小合适的数据占用,仍然无法将其彻底占用,就形成了碎片;

(3)当 MySQL 对数据进行扫描时,它扫描的对象实际是列表的容量需求上限,也就是数据被写入的区域中处于峰值位置的部分;

清除碎片的优点:

降低访问表时的 IO,提高 mysql 性能,释放表空间降低磁盘空间使用率

注意

1.MySQL 官方建议不要经常 (每小时或每天) 进行碎片整理,一般根据实际情况,只需要每周或者每月整理一次即可 (我们现在是每月凌晨 4 点清理 mysql 所有实例下的表碎片)。

2.在 OPTIMIZE TABLE 运行过程中,MySQL 会锁定表。因此,这个操作一定要在网站访问量较少的时间段进行。

3.清理 student 的 105 万条数据, OPTIMIZE TABLE 库.student;本地测试需要 37 秒。

自测

大家可以用这条语句看看自己的系统的 datafree 大不大

show table status from 表名;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值