溫馨提示×

溫馨提示×

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

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

GlusterFS復(fù)制卷修復(fù)原理是什么

發(fā)布時間:2021-08-05 21:24:29 來源:億速云 閱讀:167 作者:chen 欄目:大數(shù)據(jù)

這篇文章主要介紹“GlusterFS復(fù)制卷修復(fù)原理是什么”,在日常操作中,相信很多人在GlusterFS復(fù)制卷修復(fù)原理是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”GlusterFS復(fù)制卷修復(fù)原理是什么”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

裂腦

    所謂腦裂,就是指兩個或多個節(jié)點都“認(rèn)為”自身是正常節(jié)點而互相“指責(zé)”對方,導(dǎo)致不能選取正確的節(jié)點進(jìn)行接管或修復(fù),導(dǎo)致腦裂狀態(tài)。這種現(xiàn)象出現(xiàn)在數(shù)據(jù)修復(fù)、集群管理等等高可用場景。

    Glusterfs的冗余鏡像(下文簡稱AFR)提供了數(shù)據(jù)副本功能,能夠在即使只有一個冗余節(jié)點的情況下仍能正常工作,不中斷上層應(yīng)用。當(dāng)節(jié)點恢復(fù)后,能夠?qū)?shù)據(jù)修復(fù)到一致狀態(tài),保證數(shù)據(jù)的安全。

AFR工作原理

    AFR數(shù)據(jù)修復(fù)主要涉及三個方面:ENTRY,META,DATA,我們以冗余度為2即含有兩個副本A和B的DATA修復(fù)為例進(jìn)行講解。記錄描述副本狀態(tài)的稱之為ChangeLog,記錄在每個副本文件擴展屬性里,讀入內(nèi)存后以矩陣形式判斷是否需要修復(fù)以及要以哪個副本為Source進(jìn)行修復(fù)。初始值以及正常值為0.(注:ENTRY和META,DATA分布對應(yīng)著一個數(shù)值)。

    Write的步驟可分解為:

    1)下發(fā)Write操作。

    2)加鎖Lock。

    3)向A,B副本的ChangeLog分別加1,記錄到各個副本的擴展屬性中。

    4)對A,B副本進(jìn)行寫操作。

    5)若該副本寫成功則ChangeLog減1,若該副本寫失敗則ChangLog值不變,記錄到各個副本的擴展屬性中。

    6)解鎖UnLock。

    7)向上層返回,只要有一個副本寫成功就返回成功。

    上述在AFR中是完整的一個transaction動作。根據(jù)兩個副本記錄的ChangeLog的數(shù)值確定了副本的幾種狀態(tài):

    1)WISE,智慧的,即該副本的ChangeLog中對方對應(yīng)的數(shù)值大于0而且自身對應(yīng)的數(shù)值等于0.

    2)INNOCENT,無辜的,即該副本上的ChangeLog即不指責(zé)對方也指責(zé)自己,ChangeLog全為0.

    3)FOOL,愚蠢的,即該副本上的ChangeLog是指責(zé)自己的。

    4)IGNORANT,忽略的,即該副本的ChangeLog丟失。

    所以一般情況下,會選取WISE的副本作為Sourse進(jìn)行修復(fù)。但是當(dāng)兩個節(jié)點都是WISE狀態(tài)時,這就出現(xiàn)了聲名狼藉的腦裂狀態(tài)。

AFR腦裂

    兩個副本均為WISE時發(fā)生腦裂,那么在哪種場景下會產(chǎn)生腦裂呢?我們還是以冗余度為2的情況舉一個簡單的例子:

    某文件X的兩個副本位于物理機A和物理機B上,在A和B上分別運行著進(jìn)程a和進(jìn)程b,a和b持續(xù)通過各自所在的物理機上的客戶端對文件X進(jìn)行不同的寫操作。然后物理機A和B之間網(wǎng)絡(luò)中斷,因為AFR在一個副本的情況下仍能不中斷上層應(yīng)用,所以進(jìn)程a和進(jìn)程b仍會持續(xù)運行,但因為網(wǎng)絡(luò)中斷,文件X在A和B上的副本數(shù)據(jù)不再一致且都認(rèn)為對方是異常的,當(dāng)網(wǎng)絡(luò)恢復(fù)時,兩個副本互相“指責(zé)”,即出現(xiàn)了腦裂。

    當(dāng)然這是腦裂發(fā)生的場景之一,有時候是有可能發(fā)生腦裂,而有時候是必然發(fā)生腦裂。腦裂,也是很多人關(guān)心的一個問題,不能一概而論。

    關(guān)于腦裂,不同的場景處理方法也是不同的,甚至某些場景的腦裂是無法避免的,只能盡量避免腦裂的發(fā)生。

如何預(yù)防裂腦

    預(yù)防裂腦,可以配置服務(wù)器端和客戶端的仲裁機制。

    客戶端和服務(wù)器端仲裁對比可見:GlusterFS 客戶端與服務(wù)器端仲裁機制對比。

到此,關(guān)于“GlusterFS復(fù)制卷修復(fù)原理是什么”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

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

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

AI