专栏名称: Java专栏
一个Java、Python、数据库、中间件、业内资讯、面试、学习资源等干货的知识分享社区。
目录
相关文章推荐
山东应急管理  ·  载168人客机空中起火,紧急备降!官方回应→ ·  昨天  
安徽交通广播  ·  情况通报 ·  昨天  
平安碑林  ·  喜报!西安市获授全省首批“平安金鼎” ·  昨天  
防骗大数据  ·  微信发布紧急提醒 ·  昨天  
51好读  ›  专栏  ›  Java专栏

如果MySQL磁盘满了,会发生什么?

Java专栏  · 公众号  ·  · 2020-12-23 12:20

正文

来源:https://testerhome.com/topics/23049

问题

使用命令发现磁盘使用率为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。

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

ALTER TABLE datainfo ENGINE=InnoDB;
ANALYZE TABLE datainfo;

optimize table datainfo;

僵局

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

后来的神操作

使用命令查看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

关闭mysql

service mysql stop  

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







请到「今天看啥」查看全文