Tag Archive: ibdata1

十月 29th, 2015

注意,以下操作会删除数据库,请事先自行备份数据库文件

一、需要3个文件,以下为3个文件的文件名及内容:

文件1:Mysql_Drop_DataBase.txt,内容如下:

drop database yourdatabase;

文件2:Mysql_Create_DataBase.txt,内容如下:

create database yourdatabase;

文件3:自动压缩ibdata1文件容量.bat,内容如下:

rem 删除数据库
mysql -u 用户名 –password=密码 < “Mysql_Drop_DataBase.txt”

rem 停止mysql服务
net stop mysql

rem 删除ibdata1、iblogfile0、ib_logfile1文件,请自行替换以下文件路径
Del “G:\MySQL Datafiles\ibdata1”
Del “C:\ProgramData\MySQL\MySQL Server 5.5\data\ib_logfile0”
Del “C:\ProgramData\MySQL\MySQL Server 5.5\data\ib_logfile1”

rem 启动mysql服务
net start mysql

rem 创建数据库
mysql -u 用户名 –password=用户名 < “Mysql_Create_DataBase.txt”

二、点击“自动压缩ibdata1文件容量.bat”开始运行

TAGS: ,
九月 28th, 2015

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

说明: mysql有多种存储引擎,比如MyISAM、InnoDB很常用。 如果用的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文件了,它们在相应数据库的文件夹下面。

TAGS: ,