您好,登錄后才能下訂單哦!
先看拓?fù)鋱D:
每個(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,如下圖:
增加一個(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里的:
現(xiàn)在添加一個(gè)新的zone:
現(xiàn)在把新的分區(qū)添加到build文件里:
此時(shí)原來分布在swiftloopbak里的數(shù)據(jù)會搬到新的zone里:
上傳一些新的文件測試:
免責(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)容。