您好,欢迎访问一九零五行业门户网

为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]
其它类似信息

推荐信息