mysql表空间_MySQL 表空间

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值