深入了解復(fù)制-三種復(fù)制形式

1碌上、基于語句的復(fù)制(statement-Based Replication)

MySQL5.0及之前的版本僅支持基于語句的復(fù)制(也叫做邏輯復(fù)制,logical replication)。master記錄下改變數(shù)據(jù)的查詢,然后篱昔,slave從中繼日志中讀取事件阔馋,并執(zhí)行它玛荞,這些SQL語句與master執(zhí)行的語句一樣。這種方式的優(yōu)點就是實現(xiàn)簡單呕寝。此外勋眯,基于語句的復(fù)制的二進制日志可以很好的進行壓縮,而且日志的數(shù)據(jù)量也較小下梢,占用帶寬少——例如客蹋,一個更新GB的數(shù)據(jù)的查詢僅需要幾十個字節(jié)的二進制日志。而mysqlbinlog對于基于語句的日志處理十分方便孽江。

但是讶坯,基于語句的復(fù)制并不是像它看起來那么簡單,因為一些查詢語句依賴于master的特定條件岗屏,例如辆琅,master與slave可能有不同的時間。所以这刷,MySQL的二進制日志的格式不僅僅是查詢語句婉烟,還包括一些元數(shù)據(jù)信息,例如暇屋,當前的時間戳似袁。即使如此,還是有一些語句,比如昙衅,CURRENT USER函數(shù)扬霜,不能正確的進行復(fù)制。此外而涉,存儲過程和觸發(fā)器也是一個問題著瓶。

另外一個問題就是基于語句的復(fù)制必須是串行化的。這要求大量特殊的代碼婴谱,配置蟹但,例如InnoDB的next-key鎖等。并不是所有的存儲引擎都支持基于語句的復(fù)制谭羔。

如果語句含有任何不確定的函數(shù)調(diào)用华糖,則可能會導(dǎo)致Master與Slave之間產(chǎn)生不一致的情況。這些函數(shù)有:

LOAD_FILE(filename):讀取文件瘟裸,以字符串的形式返回值客叉。

UUID():生成唯一值的函數(shù),128位。

UUID_SHORT():同UUID(),64位话告。

USER():以utf8字符集返回當前連接MySQL的用戶名及主機名兼搏。

FOUND_ROWS():返回一個包含limit字句獲得的查詢總數(shù)。

SYSDATE():返回動態(tài)執(zhí)行的時間沙郭。

GET_LOCK(str,timeout) :獲得一個以字符串命名的鎖佛呻,且有超時時間。

IS_USED_LOCK(str):檢測str命名的鎖是否在使用中病线。

IS_FREE_LOCK(str):檢測str命名的鎖是否沒在使用吓著。

MASTER_POS_WAIT():控制master/slave的同步。

RAND():實現(xiàn)隨機數(shù)的方法送挑。

RELEASE_LOCK():用來釋放因GET_LOCK()獲取鎖的str绑莺。

SLEEP():實現(xiàn)延遲動作的時間的方法。

VERSION():返回MySQL版本信息的函數(shù)惕耕。

2纺裁、基于行的復(fù)制(Row-Based Replication)

MySQL增加基于行的復(fù)制,在二進制日志中記錄下實際數(shù)據(jù)的改變司澎。這種方式有優(yōu)點欺缘,也有缺點。優(yōu)點就是可以對任何語句都能正確工作挤安,一些語句的效率更高浪南。主要的缺點就是二進制日志可能會很大,而且不直觀漱受,所以,你不能使用mysqlbinlog來查看二進制日志。

對于一些語句昂羡,基于記錄的復(fù)制能夠更有效的工作絮记,如:

mysql> INSERT INTO summary_table(col1, col2, sum_col3)

-> SELECTcol1, col2, sum(col3)

-> FROMenormous_table

-> GROUP BYcol1, col2;

假設(shè),只有三種唯一的col1和col2的組合虐先,但是怨愤,該查詢會掃描原表的許多行,卻僅返回三條記錄蛹批。此時撰洗,基于記錄的復(fù)制效率更高。

另一方面腐芍,下面的語句差导,基于語句的復(fù)制更有效:

mysql> UPDATEenormous_table SET col1 = 0;

此時使用基于記錄的復(fù)制代價會非常高。由于兩種方式不能對所有情況都能很好的處理猪勇,所以设褐,MySQL 5.1支持在基于語句的復(fù)制和基于記錄的復(fù)制之前動態(tài)交換。你可以通過設(shè)置session變量binlog_format來進行控制泣刹。

3助析、混合復(fù)制

MySQL5.1及其以后的版本推薦使用混合模式的復(fù)制,它是根據(jù)事件的類型實時的改變binlog的格式椅您。當設(shè)置為混合模式時外冀,默認為基于語句的格式,但在特定的情況下它會自動轉(zhuǎn)變?yōu)榛谛械哪J健?/p>

當出現(xiàn)如下情況時掀泳,混合模式需要切換到基于行的復(fù)制:

該語句調(diào)用了:

UUID函數(shù)雪隧;

用戶自定義函數(shù)(UDFs);

CURRENT_USER或USER函數(shù);

LOAD_FILE函數(shù)开伏。

.同一個語句更改了兩張或更多包含AUTO_INCREMENT列的表膀跌。

.語句中使用了服務(wù)器變量。

.存儲引擎不允許使用基于語句復(fù)制固灵,如:MySQL Cluster引擎捅伤。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市巫玻,隨后出現(xiàn)的幾起案子丛忆,更是在濱河造成了極大的恐慌,老刑警劉巖仍秤,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件熄诡,死亡現(xiàn)場離奇詭異,居然都是意外死亡诗力,警方通過查閱死者的電腦和手機凰浮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人袜茧,你說我怎么就攤上這事菜拓。” “怎么了笛厦?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵纳鼎,是天一觀的道長。 經(jīng)常有香客問我裳凸,道長贱鄙,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任姨谷,我火速辦了婚禮逗宁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘菠秒。我一直安慰自己疙剑,他們只是感情好,可當我...
    茶點故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布践叠。 她就那樣靜靜地躺著言缤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪禁灼。 梳的紋絲不亂的頭發(fā)上管挟,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天,我揣著相機與錄音弄捕,去河邊找鬼僻孝。 笑死,一個胖子當著我的面吹牛守谓,可吹牛的內(nèi)容都是我干的穿铆。 我是一名探鬼主播,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼斋荞,長吁一口氣:“原來是場噩夢啊……” “哼荞雏!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起平酿,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤凤优,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后蜈彼,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體筑辨,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年幸逆,在試婚紗的時候發(fā)現(xiàn)自己被綠了棍辕。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片暮现。...
    茶點故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖痢毒,靈堂內(nèi)的尸體忽然破棺而出送矩,到底是詐尸還是另有隱情,我是刑警寧澤哪替,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站菇怀,受9級特大地震影響凭舶,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜爱沟,卻給世界環(huán)境...
    茶點故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一帅霜、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧呼伸,春花似錦身冀、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至铃辖,卻和暖如春剩愧,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背娇斩。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工仁卷, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人犬第。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓锦积,卻偏偏與公主長得像,于是被迫代替她去往敵國和親歉嗓。 傳聞我的和親對象是個殘疾皇子丰介,可洞房花燭夜當晚...
    茶點故事閱讀 45,860評論 2 361

推薦閱讀更多精彩內(nèi)容