码迷,mamicode.com
首页 > 数据库 > 详细

MySQL ibdata1占用空间大 释放MySQL ibdata1文件的空间

时间:2015-09-22 14:45:15      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:mysql   数据库   空间释放   ibdata1   

                    MySQL ibdata1占用空间大  释放MySQL ibdata1文件的空间


背景:最近公司一台服务器报警,磁盘空间报警超阀值.  原来mysql数据库数据目录特别大,前一篇文章中介绍的是变更mysql数据文件的目录,此文主要介绍如何把mysql占用的空间释放出来。



说明: mysql有多种存储引擎,比如MyISAMInnoDB很常用。 如果用的InnoDB, 且使用mysql默认的配置文件,MySQL的数据都会存放在ibdata1文件中,经过一段时间此文件会变的非常大,占用大量磁盘空间。如何把mysql占用的空间释放出来。


mysql ibdata1存放数据,索引等,是MYSQL的最主要的数据。

步骤:

1,备份数据库

备份全部数据库,执行命令mysqldump  -uusername -ppassword  --all-databases > /backup/all.sql 或者只备份需要的库。



删除数据库
drop database A;
drop database B;



停止数据库: service mysqld stop


2,修改mysql配置文件

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

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文件了,它们在相应数据库的文件夹下面。

 


本文出自 “技术成就梦想” 博客,请务必保留此出处http://pizibaidu.blog.51cto.com/1361909/1697016

MySQL ibdata1占用空间大 释放MySQL ibdata1文件的空间

标签:mysql   数据库   空间释放   ibdata1   

原文地址:http://pizibaidu.blog.51cto.com/1361909/1697016

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!