MySQL 表空间
环境:MySQL 5.6.27, Ubuntu 15.10 64-bit
引擎为 InnoDB,不考虑 MyISAM。MySQL 5.6 版之前的 InnoDB 不支持独立表空间。
查看当前设置是共享表空间,还是独立表空间
mysql> show variables like '%per_table%';
+-----------------------+-------+
| Variable_name | Value |
+-----------------------+-------+
| innodb_file_per_table | ON |
+-----------------------+-------+
1 row in set (0.00 sec)
innodb_file_per_table
为 ON
,所以为独立表空间。
MySQL数据库文件的位置
/var/lib/mysql/
但是发现一般用户无法访问:
$ cd /var/lib/mysql
bash: cd: /var/lib/mysql: 权限不够
可以为当前用户添加权限:
$ sudo chmod +rx -R mysql
但是感觉这样不太好。还是切换到 root
用户吧:
$ sudo su
查看数据库文件目录
数据库 menagerie
里有两个表,user
和 pet
。查看数据库文件:
root@t450s:/var/lib/mysql/menagerie# ll
总用量 228
drwx------ 2 mysql mysql 4096 10月 31 21:12 ./
drwxr-xr-x 5 mysql mysql 4096 10月 31 20:28 ../
-rw-rw---- 1 mysql mysql 65 9月 21 15:41 db.opt
-rw-rw---- 1 mysql mysql 8720 9月 21 15:48 pet.frm
-rw-rw---- 1 mysql mysql 98304 9月 21 17:06 pet.ibd
-rw-rw---- 1 mysql mysql 8620 10月 31 21:12 user.frm
-rw-rw---- 1 mysql mysql 98304 10月 31 21:12 user.ibd
可见 user
和 pet
各有一个 .ibd
文件,即表空间为独立的。
切换至共享表空间
首先停掉 MySQL 服务(好像旧版名为 mysqld
):
adam@t450s:~$ sudo /etc/init.d/mysql stop
[ ok ] Stopping mysql (via systemctl): mysql.service.
添加如下配置到 /etc/mysql/my.cnf
:
[mysqld]
innodb_file_per_table = 0
再启动 MySQL 服务:
adam@t450s:~$ /etc/init.d/mysql start
[ ok ] Starting mysql (via systemctl): mysql.service.
在 MySQL 客户端里看一下:
mysql> show variables like '%per_table%';
+-----------------------+-------+
| Variable_name | Value |
+-----------------------+-------+
| innodb_file_per_table | OFF |
+-----------------------+-------+
1 row in set (0.00 sec)
现在配置确实为共享表空间。
重新创建数据库 menagerie
及两张表。然后查看数据库文件:
root@t450s:/var/lib/mysql/menagerie# ll
总用量 36
drwx------ 2 mysql mysql 4096 11月 1 13:05 ./
drwxr-xr-x 5 mysql mysql 4096 11月 1 13:05 ../
-rw-rw---- 1 mysql mysql 65 11月 1 12:18 db.opt
-rw-rw---- 1 mysql mysql 8720 11月 1 12:20 pet.frm
-rw-rw---- 1 mysql mysql 8620 11月 1 12:20 user.frm
新建的表为共享表空间。
再转换成独立表空间
mysql> set global innodb_file_per_table=1;
mysql> alter table user engine=InnoDB;
mysql> alter table pet engine=InnoDB;
查看数据库文件。
root@t450s:/var/lib/mysql/menagerie# ll
总用量 228
drwx------ 2 mysql mysql 4096 11月 1 13:17 ./
drwxr-xr-x 5 mysql mysql 4096 11月 1 13:05 ../
-rw-rw---- 1 mysql mysql 65 11月 1 12:18 db.opt
-rw-rw---- 1 mysql mysql 8720 11月 1 13:16 pet.frm
-rw-rw---- 1 mysql mysql 98304 11月 1 13:16 pet.ibd
-rw-rw---- 1 mysql mysql 8620 11月 1 13:17 user.frm
-rw-rw---- 1 mysql mysql 98304 11月 1 13:17 user.ibd
改表空间还可以用 ALTER TABLE ... TABLESPACE
,详见:Enabling and Disabling File-Per-Table Tablespaces