溫馨提示×

溫馨提示×

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

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

openstack-Swift中ring的通俗理解

發(fā)布時(shí)間:2020-06-30 21:25:57 來源:網(wǎng)絡(luò) 閱讀:1112 作者:lduan 欄目:移動開發(fā)

先看拓?fù)鋱D:

openstack-Swift中ring的通俗理解 

每個(gè)文件和虛擬節(jié)點(diǎn)之間是一對一的關(guān)系,每上傳一個(gè)文件就會分配一個(gè)虛擬節(jié)點(diǎn),虛擬節(jié)點(diǎn)數(shù)一般是2的n次冪。

每個(gè)虛擬節(jié)點(diǎn)和zone是一對多的關(guān)系,假設(shè)每個(gè)文件有兩個(gè)副本的話,那么每個(gè)虛擬節(jié)點(diǎn)對應(yīng)到兩個(gè)zone,這里只討論文件只有一個(gè)副本,所以一個(gè)虛擬節(jié)點(diǎn)只對應(yīng)到一個(gè)zone。

而一個(gè)zone可以對應(yīng)到多個(gè)虛擬節(jié)點(diǎn),比如上圖有6個(gè)虛擬節(jié)點(diǎn)3個(gè)zone,那么每個(gè)zone對應(yīng)兩個(gè)虛擬節(jié)點(diǎn)。如果2^n個(gè)虛擬節(jié)點(diǎn)怎么分配給zone,就要看每個(gè)zone的權(quán)重(weight)了。

如上圖,file1對應(yīng)的1號虛擬節(jié)點(diǎn),1號虛擬節(jié)點(diǎn)對應(yīng)的是zone1,所以file1是存儲在zone1里的,file2對應(yīng)的4號虛擬節(jié)點(diǎn),4號虛擬節(jié)點(diǎn)對應(yīng)的是z1,那么file2也是存儲在zone1里的(這里假設(shè)file4對應(yīng)的是4號虛擬節(jié)點(diǎn))。

現(xiàn)在準(zhǔn)備在環(huán)境里添加一個(gè)新的zone,如下圖:

openstack-Swift中ring的通俗理解 

增加一個(gè)新的zone之后,那么虛擬節(jié)點(diǎn)和zone之間的對應(yīng)關(guān)系就要重新分配(rebalance),如上圖。

此時(shí)4號虛擬節(jié)點(diǎn)對應(yīng)的是zone4,按照現(xiàn)在的分配,file2應(yīng)該是存儲在zone4里,但是根據(jù)前面的分析,file2已經(jīng)存儲在zone1里了,那么就要開始把file2從zone1復(fù)制到zone4里去。

下面開始測試:

當(dāng)前swift就使用一個(gè)zone,所以這三個(gè)對象都是放在同一個(gè)zone里的:

openstack-Swift中ring的通俗理解 

現(xiàn)在添加一個(gè)新的zone:

openstack-Swift中ring的通俗理解 

現(xiàn)在把新的分區(qū)添加到build文件里:

openstack-Swift中ring的通俗理解 

 

openstack-Swift中ring的通俗理解 

此時(shí)原來分布在swiftloopbak里的數(shù)據(jù)會搬到新的zone里:

openstack-Swift中ring的通俗理解 上傳一些新的文件測試:

openstack-Swift中ring的通俗理解


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

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

AI