释放MySQL ibdata1文件的空间

本文介绍如何在MySQL中配置InnoDB存储引擎,使其为每个表使用单独的.ibd文件,而不是将所有数据存储在一个大的ibdata1文件中。通过详细步骤指导读者完成配置更改、备份与恢复数据库的过程。
在MySQL数据库中,如果不指定innodb_file_per_table参数,单独存在每个表的数据,MySQL的数据都会存放在ibdata1文件。
mysql ibdata1存放数据,索引等,是MYSQL的最主要的数据。


步骤:


1,备份数据库


从命令行进入MySQL Server 5.1/bin
备份全部数据库,执行命令mysqldump -q -uusername -pyourpassword --add-drop-table --all-databases > /backup/all.sql


除数据库
drop database db1;
drop database db2;


此处不删除应用数据库,在全库恢复数据库时,就会报异常错误,一些表的*.ibd会报不存在。


解决方式:


movo db1 /backup/db1_bak


movo db2 /backup/db2_bak


做完此步后,然后停止数据库。




2,修改mysql配置文件


修改my.cnf文件,增加下面配置


innodb_file_per_table


对每张表使用单独的innoDB文件, 修改/etc/my.cnf文件


3,删除原数据文件


删除原来的ibdata1文件及日志文件ib_logfile*,删除data目录下的应用数据库文件夹(mysql,test,information_schema数据库本身文件夹不要删除)


4,还原数据库


启动数据库服务


从命令行进入MySQL Server 5.1/bin
还原全部数据库,执行命令mysql -uusername -pyourpassword < /all.sql


大公告成。


经过以上几步后,可以看到新的ibdata1文件就只有几十M了,数据及索引都变成了针对单个表的小ibd文件了,它们在相应数据库的文件夹下面。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值