背景:最近公司一台服务器报警,磁盘空间报警超阀值. 原来mysql数据库数据目录特别大,前一篇文章中介绍的是变动mysql数据文件的目录,此文主要介绍如何把mysql占用的空间释放出来。mysql
说明: mysql有多种存储引擎,好比MyISAM、InnoDB很经常使用。 若是用的InnoDB, 且使用mysql默认的配置文件,MySQL的数据都会存放在ibdata1文件中,通过一段时间此文件会变的很是大,占用大量磁盘空间。如何把mysql占用的空间释放出来。sql
mysql ibdata1存放数据,索引等,是MYSQL的最主要的数据。数据库
步骤:服务器
1,备份数据库ide
备份所有数据库,执行命令mysqldump -uusername -ppassword --all-databases > /backup/all.sql 或者只备份须要的库。spa
删除数据库
drop database A;
drop database B;日志
中止数据库: service mysqld stop
orm
2,修改mysql配置文件索引
修改my.cnf文件,增长下面配置it
innodb_file_per_table
对每张表使用单独的innoDB文件, 修改/etc/my.cnf文件
3,删除原数据文件
删除原来的ibdata1文件及日志文件ib_logfile*,删除data目录下的应用数据库文件夹(mysql,test,information_schema数据库自己文件夹不要删除)
4,还原数据库
启动数据库服务service mysqld start
还原所有数据库,执行命令mysql -uusername -ppassword <all.sql
通过以上几步后,能够看到新的ibdata1文件就只有几十M了,数据及索引都变成了针对单个表的小ibd文件了,它们在相应数据库的文件夹下面。