红联Linux门户
Linux帮助

MySQL表空间

发布时间:2015-11-06 09:44:42来源:linux网站作者:linux人

环境: 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, 详见:
http://dev.mysql.com/doc/refman/5.6/en/tablespace-enabling.html


Linux环境下oracle创建和删除表空间及用户:http://www.linuxdiyf.com/linux/14999.html

通过Shell脚本查看数据库表空间使用情况:http://www.linuxdiyf.com/linux/11907.html

undo表空间概述:http://www.linuxdiyf.com/linux/9424.html