mysql数据文件瘦身_为MySQL数据文件ibdata1瘦身

欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入 MySQL在运行一段时间后,ibdata1的文件会增长大小,就算删除了表的数据,ibdata1的体积也不会减

欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入

MySQL在运行一段时间后,ibdata1的文件会增长大小,就算删除了表的数据,ibdata1的体积也不会减小。由于硬盘空间有限,这样一直膨胀下去磁盘空间接近崩溃。今天在导出数据的时候就发现了,磁盘竟然满了,明明预留了1个月的用量,1周就占满了,下面就要给ibdata1做个瘦身。

1. 系统环境

Linux Ubuntu 13.04 64bit server

~ uname -a

Linux d2 3.8.0-21-generic #32-Ubuntu SMP Tue May 14 22:16:46 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux

~ cat /etc/issue

Ubuntu 13.04 \n \l

MySQL: 5.5.31-0ubuntu0.13.04.1

~ mysql --version

mysql Ver 14.14 Distrib 5.5.31, for debian-linux-gnu (x86_64) using readline 6.2

硬盘:36G+4G+4G+36G

~ df -h

Filesystem Size Used Avail Use% Mounted on

/dev/mapper/server3--vg-root 36G 31G 3.2G 91% /

none 4.0K 0 4.0K 0% /sys/fs/cgroup

udev 4.1G 1.1G 3.0G 26% /dev

tmpfs 824M 280K 823M 1% /run

none 5.0M 0 5.0M 0% /run/lock

none 4.1G 3.4G 729M 83% /run/shm

none 100M 0 100M 0% /run/user

/dev/vda1 228M 30M 187M 14% /boot

192.168.1.10:/home/amg/data 36G 13G 21G 39% /home/amg/data

MySQL的ibdata1占用空间:20G

~ cd /var/lib/mysql

~ ls -l

drwxr-xr-x 2 mysql mysql 4096 Aug 2 19:38 CB

drwxr-xr-x 2 mysql mysql 4096 Jun 24 23:08 conan

drwxr-xr-x 2 mysql mysql 4096 Jun 2 00:52 dbwordpress

-rwxr-xr-x 1 root root 0 May 23 00:48 debian-5.5.flag

-rwxr-xr-x 1 mysql mysql 20101201920 Aug 2 20:08 ibdata1

-rwxr-xr-x 1 mysql mysql 5242880 Aug 2 20:08 ib_logfile0

-rwxr-xr-x 1 mysql mysql 5242880 Aug 2 19:38 ib_logfile1

drwxr-xr-x 2 mysql mysql 4096 Jun 26 09:03 Macro

drwxr-xr-x 2 mysql root 4096 May 23 00:48 mysql

-rwxr-xr-x 1 root root 6 May 23 00:48 mysql_upgrade_info

drwxr-xr-x 2 mysql mysql 4096 May 23 00:48 performance_schema

drwxr-xr-x 2 mysql mysql 4096 May 23 00:53 phpmyadmin

drwxr-xr-x 2 mysql root 4096 May 23 00:48 test

drwxr-xr-x 2 mysql mysql 4096 Jul 22 14:09 TF

drwxr-xr-x 2 mysql mysql 4096 Jun 2 01:04 wordpress

业务数据表

mysql> show tables;

+-----------------+

| Tables_in_CB |

+-----------------+

| NSpremium |

| cb_hft |

| cb_hft_20130801 |

| cb_hft_20130802 |

+-----------------+

4 rows in set (0.00 sec)

2. 发现问题

ibdata1单个文件占用20G大小。

1. MySQL默认设置,没有按表空间分离数据,所有的表的数据都被放到ibdata1文件中。

2. 业务操作,每天会产生一张表cb_hft,晚上的时候对表进行重命名。

RENAME TABLE cb_hft TO cb_hft_20130801;

create table cb_hft like cb_hft_20130801;

[1] [2] [3]

test.jsp?url=http%3A%2F%2Fwww.chinaitlab.com%2Fcms%2Fimages%2Flogo14.gif&refer=http%3A%2F%2FLinux.chinaitlab.com%2FMYSQL%2F936266.html

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
清理 `ibdata1` 数据需要谨慎操作,因为这是 MySQL 的核心数据文件,包含了所有的表结构和数据。如果清理不当,可能导致数据丢失或 MySQL 无法启动。 以下是清理 `ibdata1` 数据的步骤: 1. 备份数据:在进行任何操作之前,请先备份 MySQL 数据。 2. 停止 MySQL 服务。 3. 进入 MySQL 数据目录,找到 `ibdata1` 文件和 `ib_logfile*` 文件,这些文件都是 MySQL 的核心数据文件。 4. 删除 `ibdata1` 文件和 `ib_logfile*` 文件。 5. 修改 MySQL 配置文件 `my.cnf`,添加以下内容: ``` innodb_file_per_table = 1 ``` 这个参数的作用是让每个 InnoDB 表的数据单独存放在一个 `.ibd` 文件中,而不是存放在 `ibdata1` 文件中。 6. 启动 MySQL 服务。 7. 对于每个 InnoDB 表,将其数据导出到一个 `.sql` 文件中,然后删除该表。导出表数据的命令如下: ``` mysqldump -u username -p dbname table_name > table_name.sql ``` 其中 `username` 是 MySQL 用户名,`dbname` 是数据库名,`table_name` 是表名。 8. 创建新的 InnoDB 表,将导出的数据导入新表中。创建表的命令如下: ``` CREATE TABLE table_name (...) ENGINE=InnoDB; ``` 其中 `...` 是表的列定义。 将数据导入新表的命令如下: ``` mysql -u username -p dbname < table_name.sql ``` 9. 重复步骤 7 和 8,直到所有的 InnoDB 表都被清理。 10. 删除备份数据。 请注意,清理 `ibdata1` 数据是一个非常危险的操作,需要谨慎操作。如果您不确定自己的操作,建议寻求专业人士的帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值