MySQL 表空间
MySQL 表空間
環(huán)境:MySQL 5.6.27, Ubuntu 15.10 64-bit
引擎為 InnoDB,不考慮 MyISAM。MySQL 5.6 版之前的 InnoDB 不支持獨立表空間。
查看當(dāng)前設(shè)置是共享表空間,還是獨立表空間
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數(shù)據(jù)庫文件的位置
/var/lib/mysql/但是發(fā)現(xiàn)一般用戶無法訪問:
$ cd /var/lib/mysql bash: cd: /var/lib/mysql: 權(quán)限不夠可以為當(dāng)前用戶添加權(quán)限:
$ sudo chmod +rx -R mysql但是感覺這樣不太好。還是切換到 root 用戶吧:
$ sudo su查看數(shù)據(jù)庫文件目錄
數(shù)據(jù)庫 menagerie 里有兩個表,user 和 pet。查看數(shù)據(jù)庫文件:
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 服務(wù)(好像舊版名為 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 服務(wù):
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)現(xiàn)在配置確實為共享表空間。
重新創(chuàng)建數(shù)據(jù)庫 menagerie 及兩張表。然后查看數(shù)據(jù)庫文件:
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新建的表為共享表空間。
再轉(zhuǎn)換成獨立表空間
mysql> set global innodb_file_per_table=1; mysql> alter table user engine=InnoDB; mysql> alter table pet engine=InnoDB;查看數(shù)據(jù)庫文件。
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
總結(jié)
- 上一篇: 使用树莓派和kali Linux打造便携
- 下一篇: springmvc+mybatis+aj