溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何理解Redis主從復(fù)制的全量和增量同步

發(fā)布時(shí)間:2021-11-12 15:06:14 來(lái)源:億速云 閱讀:199 作者:柒染 欄目:關(guān)系型數(shù)據(jù)庫(kù)

如何理解Redis主從復(fù)制的全量和增量同步,針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

全量同步:
1.slave服務(wù)器連接到master服務(wù)器,發(fā)送SYNC命令
     slave服務(wù)器通過(guò) syncWithMaster() 函數(shù)來(lái)連接 Master 服務(wù)器(如果Master服務(wù)器需要密碼登錄的話,先登錄),并且發(fā)送SYNC命令請(qǐng)求同步,接著打開 rdb 文件(用于存儲(chǔ)由Master發(fā)送過(guò)來(lái)的數(shù)據(jù)),創(chuàng)建讀rdb 的 IO 事件(readSyncBulkPayload)
2.master服務(wù)器備份數(shù)據(jù)庫(kù)到 .rdb 文件
     當(dāng)slave服務(wù)器發(fā)送SYNC命令到master服務(wù)器時(shí),master 服務(wù)器變回調(diào)用 syncCommand() 函數(shù)來(lái)進(jìn)行同步,同步的第一步便是把數(shù)據(jù)庫(kù)的數(shù)據(jù)存儲(chǔ)為 rdb 文件,存儲(chǔ)完畢后調(diào)用updateSalvesWaitingBgsave()函數(shù)來(lái)發(fā)送 rdb 文件給所有的slave 服務(wù)器,updateSlavesWaitingBgsave() 要做的事情是, 打開 rdb 文件, 創(chuàng)建發(fā)送 rdb 文件 IO 事件(sendBulkToSlave). 而sendBulkToSlave()主要的工作就是把rdb文件發(fā)送給 Slave 服務(wù)器。而當(dāng) Slave 服務(wù)器接收 rdb 文件完畢之后(readSyncBulkPayload()函數(shù)處理), 會(huì)清空原來(lái)數(shù)據(jù)庫(kù)的數(shù)據(jù),然后把 rdb 文件的數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫(kù)中
3.全量同步完成
     完成上面的步驟,全量同步基本完成。
增量同步:
     增量同步就是當(dāng) master 服務(wù)器有數(shù)據(jù)更新的時(shí)候,會(huì)立刻同步到所有的 slave 服務(wù)器
1.當(dāng)我們?cè)?master 服務(wù)器增減數(shù)據(jù)的時(shí)候,就會(huì)觸發(fā) replicationFeedSalves()函數(shù),接下來(lái)在 Master 服務(wù)器上調(diào)用的每一個(gè)命令都會(huì)使用replicationFeedSlaves() 函數(shù)來(lái)同步到Slave服務(wù)器。當(dāng)然,在執(zhí)行此函數(shù)之前master 服務(wù)器會(huì)判斷用戶執(zhí)行的命令是否有數(shù)據(jù)更新,如果有數(shù)據(jù)更新并且slave 服務(wù)器不為空,才會(huì)執(zhí)行此函數(shù),而此函數(shù)主要的工作就是把用戶執(zhí)行的命令發(fā)送到所有的 slave服務(wù)器,讓 slave 服務(wù)器執(zhí)行,這樣就可以實(shí)施同步功能了。

關(guān)于如何理解Redis主從復(fù)制的全量和增量同步問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI