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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL 表空间

發布時間:2025/3/19 数据库 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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

改表空間還可以用 ALTER TABLE ... TABLESPACE,詳見:Enabling and Disabling File-Per-Table Tablespaces

總結

以上是生活随笔為你收集整理的MySQL 表空间的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。