日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

MySQL 表空间

發(fā)布時(shí)間:2025/3/19 数据库 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL 表空间 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

MySQL 表空間

環(huán)境:MySQL 5.6.27, Ubuntu 15.10 64-bit
引擎為 InnoDB,不考慮 MyISAM。MySQL 5.6 版之前的 InnoDB 不支持獨(dú)立表空間。

查看當(dāng)前設(shè)置是共享表空間,還是獨(dú)立表空間

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,所以為獨(dú)立表空間。

MySQL數(shù)據(jù)庫(kù)文件的位置

/var/lib/mysql/

但是發(fā)現(xiàn)一般用戶無(wú)法訪問(wè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ù)庫(kù)文件目錄

數(shù)據(jù)庫(kù) menagerie 里有兩個(gè)表,user 和 pet。查看數(shù)據(jù)庫(kù)文件:

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 各有一個(gè) .ibd 文件,即表空間為獨(dú)立的。

切換至共享表空間

首先停掉 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

再啟動(dòng) 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)在配置確實(shí)為共享表空間。

重新創(chuàng)建數(shù)據(jù)庫(kù) menagerie 及兩張表。然后查看數(shù)據(jù)庫(kù)文件:

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)換成獨(dú)立表空間

mysql> set global innodb_file_per_table=1; mysql> alter table user engine=InnoDB; mysql> alter table pet engine=InnoDB;

查看數(shù)據(jù)庫(kù)文件。

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é)

以上是生活随笔為你收集整理的MySQL 表空间的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。