mysql之 表空間傳輸
說明:MySQL(5.6.6及以上),innodb_file_per_table開啟。
1.1. 操作步驟:
0. 目標伺服器建立相同表結構
1. 目的伺服器: ALTER TABLE t DISCARD TABLESPACE;
2. 源伺服器 : FLUSH TABLES t FOR EXPORT;
3. 從源伺服器上 複製t.ibd, t.cfg檔案到目的伺服器
4. 源伺服器: UNLOCK TABLES;
5. 目的伺服器: ALTER TABLE t IMPORT TABLESPACE;
1.2. 演示
將多例項的 [mysql5711] 中 burn_test 庫下的test_purge表 ,傳輸到 [mysql57112]中 burn_test2 庫下的test_purge表
1.2.1. 準備工作
1. 在 目標伺服器 上建立表空間
-- 源伺服器 [mysql5711]
mysql> select * from burn_test.test_purge;
+----+------+
| a | b |
+----+------+
| 1 | 10 |
| 3 | 30 |
| 4 | 40 |
| 5 | 50 |
| 6 | 60 |
| 7 | 70 |
| 8 | 80 |
| 10 | 100 |
+----+------+
8 rows in set (0.01 sec)
-- 目標伺服器 [mysql57112]
--
-- test_purge在 目標伺服器 上不存在,先建立該表
mysql> CREATE TABLE `test_purge` (
`a` int(11) NOT NULL AUTO_INCREMENT,
`b` int(11) DEFAULT NULL,
PRIMARY KEY (`a`),
UNIQUE KEY `b` (`b`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8mb4;
Query OK, 0 rows affected (0.16 sec)
2. 建立完成後進行檢查
#
# 目標伺服器
#
[root@MyServer burn_test_2]> ll | grep test_purge
-rw-r-----. 1 mysql mysql 8578 Mar 21 10:31 test_purge.frm # 表結構
-rw-r-----. 1 mysql mysql 57344 Mar 21 10:31 test_purge.ibd # 表空間,需要透過 DISCARD 將表空間檔案刪除
ALTER TABLE test_purge DISCARD TABLESPACE; 的含義是 保留test_purge.frm 檔案, 刪除test_purge.ibd
3. 通闢 discard 刪除ibd檔案
-- 目標伺服器
mysql> alter table test_purge discard tablespace;
Query OK, 0 rows affected (0.04 sec)
mysql> show tables;
+-----------------------+
| Tables_in_burn_test_2 |
+-----------------------+
| test_backup1 |
| test_purge |
+-----------------------+
2 rows in set (0.00 sec)
mysql> select * from test_purge;
ERROR 1814 (HY000): Tablespace has been discarded for table 'test_purge'
[root@MyServer burn_test_2]> ll | grep test_purge
-rw-r-----. 1 mysql mysql 8578 Mar 21 10:31 test_purge.frm
1.2.2. 匯出表空間
1. 在源伺服器上,通闢 export 命令匯出表空間(同時加讀鎖)
-- 源伺服器
mysql> flush table test_purge for export; -- 其實是對這個表加一個讀鎖
Query OK, 0 rows affected (0.00 sec)
2. 將匯出的 cfg檔案 和 ibd檔案 , 複製到目標伺服器 的資料庫下
#
# 源伺服器
#
[root@MyServer burn_test]> ll | grep test_purge
-rw-r-----. 1 mysql mysql 462 Mar 21 10:58 test_purge.cfg # export後,多出來的檔案,裡面儲存了一些後設資料資訊
-rw-r-----. 1 mysql mysql 8578 Mar 4 15:41 test_purge.frm
-rw-r-----. 1 mysql mysql 57344 Mar 5 15:28 test_purge.ibd
[root@MyServer burn_test]> cp test_purge.cfg test_purge.ibd /data/mysql_data/5.7.11_2/burn_test_2/ # 複製表空間和cfg檔案,遠端請使用scp(本地多例項演示,這裡的庫名是不同的)
3. 匯出表空間後,儘快解鎖
-- 源伺服器
mysql> unlock tables; -- 儘快的解鎖
Query OK, 0 rows affected (0.00 sec)
注意:一定要先複製cfg和ibd檔案,然後才能unlock,因為 unlock 的時候, cfg檔案會被刪除
# 源伺服器上的日誌
[Note] InnoDB: Stopping purge # 其實stop purge,找個測試的表 for export 即可
[Note] InnoDB: Writing table metadata to './burn_test/test_purge.cfg'
[Note] InnoDB: Table `burn_test`.`test_purge` flushed to disk
[Note] InnoDB: Deleting the meta-data file './burn_test/test_purge.cfg' # unlock table後,該檔案自動被刪除
[Note] InnoDB: Resuming purge # unlock後,恢復purge執行緒
4. 在目標伺服器上 修改 cfg檔案和ibd檔案的 許可權
#
# 目標伺服器
#
[root@MyServer burn_test_2]> chown mysql.mysql test_purge.cfg test_purge.ibd
5. 在目標伺服器上通闢 import 命令匯入表空間
-- 目標伺服器
--
mysql> alter table test_purge import tablespace; -- 匯入表空間
Query OK, 0 rows affected (0.24 sec)
mysql> select * from test_purge; -- 可以讀取到從源伺服器複製過來的資料
+----+------+
| a | b |
+----+------+
| 1 | 10 |
| 3 | 30 |
| 4 | 40 |
| 5 | 50 |
| 6 | 60 |
| 7 | 70 |
| 8 | 80 |
| 10 | 100 |
+----+------+
8 rows in set (0.00 sec)
# error.log中出現的資訊
InnoDB: Importing tablespace for table 'burn_test/test_purge' that was exported from host 'MyServer'
注意:
表的名稱必須相同 ,經過上述測試,庫名可以不同
該方法也可以用於分割槽表的備份和恢復
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31383567/viewspace-2215161/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL 傳輸表空間MySql
- MySQL表空間傳輸MySql
- 5.7 mysql的可傳輸表空間MySql
- Oracle 表空間傳輸Oracle
- oracle表空間傳輸Oracle
- Oracle傳輸表空間Oracle
- MySQL Transportable Tablespace(傳輸表空間) 使用詳解MySql
- 傳輸表空間操作-OracleOracle
- Oracle傳輸表空間(TTS)OracleTTS
- Oracle 傳輸表空間-RmanOracle
- 總結-表空間傳輸
- 跨平臺表空間遷移(傳輸表空間)
- MySQL傳輸表空間的簡單使用方法MySql
- 【傳輸表空間】使用 EXPDP/IMPDP工具的傳輸表空間完成資料遷移
- 基於可傳輸表空間的表空間遷移
- Oracle傳輸表空間學習Oracle
- Oracle 傳輸表空間-EXPDP/IMPDPOracle
- Oracle 傳輸表空間-EXP/IMPOracle
- 傳輸表空間自包含理解
- Oracle表空間傳輸詳解Oracle
- 海量資料遷移之傳輸表空間(一)
- 【傳輸表空間】使用 EXPDP/IMPDP工具的傳輸表空間完成資料遷移[轉]
- oracle 傳輸表空間一例Oracle
- Oracle可傳輸表空間測試Oracle
- 表空間傳輸讀書筆記筆記
- 10g新特性之-跨平臺表空間傳輸
- 【XTTS】Oracle傳輸表空間xtts增量方式TTSOracle
- 傳輸表空間(從Linux到Windows)LinuxWindows
- oracle可傳輸表空間TTS小結OracleTTS
- 傳輸表空間及問題處理
- oracle表空間傳輸的限制條件Oracle
- 實戰RMAN備份傳輸表空間
- 使用Oracle可傳輸表空間的特性複製資料(7)實戰RMAN備份傳輸表空間Oracle
- MySQL傳輸表空間小結(r12筆記第2天)MySql筆記
- 12c 資料泵傳輸表空間
- 資料泵 TTS(傳輸表空間技術)TTS
- 聊聊Oracle可傳輸表空間(Transportable Tablespace)(上)Oracle
- 聊聊Oracle可傳輸表空間(Transportable Tablespace)(中)Oracle