青草久久影院-青草久久伊人-青草久久久-青草久久精品亚洲综合专区-SM双性精跪趴灌憋尿调教H-SM脚奴调教丨踩踏贱奴

17站長網

17站長網 首頁 數(shù)據(jù)庫 Mysql 查看內容

MySQL傳輸表空間總結

2023-3-16 14:23| 查看: 1842 |來源: 互聯(lián)網

在MySQL中如果要遷移一個表導另外一個服務器/環(huán)境中,常規(guī)的做法就是使用備份工具備份,比如mysqldump,然后拷貝備份到目標服務器或者環(huán)境導入。如果某一個表數(shù) ...

在MySQL中如果要遷移一個表導另外一個服務器/環(huán)境中,常規(guī)的做法就是使用備份工具備份,比如mysqldump,然后拷貝備份到目標服務器或者環(huán)境導入。如果某一個表數(shù)據(jù)量很大,導出dump文件很大的情況下,使用導出導入工具其實會花費不少的時間.

怎么樣提高效率呢,可以有一種想法就是直接拷貝數(shù)據(jù)文件到目標環(huán)境,當然在早期版本中這么做是不可取的,因為會有很多關聯(lián)數(shù)據(jù)在ibdata中,InnoDB的數(shù)據(jù)存在對應的數(shù)據(jù)字典信息,是存放在共享表空間中,無法直接剝離出來,而在5.6/5.7中,就推出了一個很不錯的特性,就是遷移表空間,可以把這個配置信息剝離出來,簡單來說就是把數(shù)據(jù)文件直接拷貝到目標環(huán)境,在目標端掛載即可。

這樣一個操作的一個基本前提是使用了獨立表空間,開啟innodb_file_per_table.

>show variables like '%per_table%';

+-----------------------+-------+

| Variable_name         | Value |

+-----------------------+-------+

| innodb_file_per_table | ON    |

+-----------------------+-------+

1 row in set (0.00 sec)

 

跨版本傳輸表空間-源端操作

我們做一個有代表意義的測試,比如把某一個表從MySQL 5.6環(huán)境遷移到MySQL 5.7環(huán)境中。

 

 我們選擇一個表users作為測試所用,數(shù)據(jù)量在2萬條左右。數(shù)據(jù)文件情況:

 

-rw-rw---- 1 mysql mysql      8602 Feb 13 23:10 users.frm

-rw-rw---- 1 mysql mysql  11534336 Mar 12 22:55 users.ibd數(shù)據(jù)情況:

 

> select count(*) from users;

+----------+

| count(*) |

+----------+

|    20001 |

+----------+

1 row in set (0.01 sec)我們開始遷移數(shù)據(jù),首先要生成一個cfg文件,導出配置信息。

  

-rw-rw---- 1 mysql mysql       599 Mar 13 08:17 users.cfg

-rw-rw---- 1 mysql mysql      8602 Feb 13 23:10 users.frm

-rw-rw---- 1 mysql mysql  11534336 Mar 12 22:55 users.ibd在flush table之后,這個表users就被鎖定了,DML操作是阻塞的,也就意味著遷移的過程中,是無法直接寫入數(shù)據(jù)的。

 

# strings users.cfg

mbionline.test.com    

test/users

userid

        username

DB_ROW_ID

DB_TRX_ID

DB_ROLL_PTR

PRIMARY

userid

DB_TRX_ID

DB_ROLL_PTR

        username

        username

        username

userid

idx_users

userid

username完成之后推出會話,設置unlock tables即可。

> alter table users import tablespace;

ERROR 1808 (HY000): Schema mismatch (Table flags don't match, server table has 0x5 and the meta-data file has 0x1)或者下面的錯誤:

> alter table users import tablespace;

ERROR 1808 (HY000): Schema mismatch (Table has ROW_TYPE_DYNAMIC row format, .ibd file has ROW_TYPE_COMPACT row format.)通過錯誤信息可以發(fā)現(xiàn)和表的一個屬性有關。我們先解決問題,添加屬性row_format

CREATE TABLE `users` (

  `userid` int(11) unsigned NOT NULL,

  `username` varchar(64) DEFAULT NULL,

  PRIMARY KEY (`userid`),

  KEY `username` (`username`),

  KEY `idx_users` (`userid`,`username`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 row_format=compact;然后繼續(xù)嘗試Import tablespace操作。

回到剛剛碰到的問題,為什么在5.6遷移至5.7會有報錯。

> alter table users import tablespace;

ERROR 1808 (HY000): Schema mismatch (Table has ROW_TYPE_DYNAMIC row format, .ibd file has ROW_TYPE_COMPACT row format.)原因就是Innodb_file_format在5.6中是Antelope,在MySQL 5.7中是Barracuda,主要是在表壓縮和行的動態(tài)格式上有所改變。更詳細的內容可以參考:

https://dev.mysql.com/doc/relnotes/mysql/5.7/en/news-5-7-7.html

小結

其實這個特性在Oracle中已經有耳熟能詳?shù)牡姆桨,TTS,支持跨平臺,轉換字節(jié)順序,甚至可以支持基于增量備份的遷移方案,MySQL中的遷移方式和Oracle傳統(tǒng)的TTS有些相似。當然上面的操作還可以使用Percona的工具innobackupex 來完成,我們下一篇來進行演示。

本文最后更新于 2023-3-16 14:23,某些文章具有時效性,若有錯誤或已失效,請在網站留言或聯(lián)系站長:17tui@17tui.com
·END·
站長網微信號:w17tui,關注站長、創(chuàng)業(yè)、關注互聯(lián)網人 - 互聯(lián)網創(chuàng)業(yè)者營銷服務中心

免責聲明:本站部分文章和圖片均來自用戶投稿和網絡收集,旨在傳播知識,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業(yè)用途,如果損害了您的權利,請聯(lián)系我們及時修正或刪除。謝謝!

17站長網微信二維碼

始終以前瞻性的眼光聚焦站長、創(chuàng)業(yè)、互聯(lián)網等領域,為您提供最新最全的互聯(lián)網資訊,幫助站長轉型升級,為互聯(lián)網創(chuàng)業(yè)者提供更加優(yōu)質的創(chuàng)業(yè)信息和品牌營銷服務,與站長一起進步!讓互聯(lián)網創(chuàng)業(yè)者不再孤獨!

掃一掃,關注站長網微信

大家都在看

    熱門排行

      最近更新

        返回頂部
        主站蜘蛛池模板: 青青草原影视 | 久久香蕉电影 | 99久久国产宗和精品1上映 | 中文字幕 人妻熟女 | 狠狠色香婷婷久久亚洲精品 | 色欲AV久久综合人妻蜜桃 | 国产性色AV内射白浆肛交后入 | 国产偷国产偷亚洲高清app | 伊人久久电影院 | gayxxxxgay呻吟受日本 | 欧美在线看费视频在线 | 久久成人午夜电影mp4 | 亚洲精品资源网在线观看 | 9277高清在线观看视频 | 日本一本二本三区免费免费高清 | 我与旗袍老师疯狂床震 | 国产AV麻豆出品在线播放 | 久久re这里视频只精品首页 | 中国午夜伦理片 | 99视频一区 | 国产精品嫩草免费视频 | 国语对白刺激真实精品 | 被老总按在办公桌吸奶头 | 无限资源网免费看 | 高hnp全肉| 国产色精品VR一区二区 | 攵女yin乱合集高h | 欧洲video60| 亚洲mv在线观看 | 国产成人无码免费精品果冻传媒 | 国产精品av | wwwwxxxx欧美| 国产呦精品一区二区三区网站 | 精品无人区麻豆乱码1区2 | 国内九一激情白浆发布 | 中文字幕永久在线 | 入禽太深免费高清在线观看5 | 三男强一女90分钟在线观看 | 性夜影院爽黄A爽免费动漫 性夜夜春夜夜爽AA片A | jizz破处| 国家产午夜精品无人区 |