



下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第如何用PHP實(shí)現(xiàn)分布算法之一致性哈希算法目錄傳統(tǒng)算法缺陷算法思想算法實(shí)現(xiàn)總結(jié)
傳統(tǒng)算法缺陷
對(duì)于服務(wù)器分布,我們要考慮的東西有如下三點(diǎn):數(shù)據(jù)平均分布,查找定位準(zhǔn)確,降低宕機(jī)影響。
傳統(tǒng)算法一般是將數(shù)據(jù)的鍵用算法映射出數(shù)字,對(duì)其用服務(wù)器數(shù)量取模,并根據(jù)結(jié)果選擇要存儲(chǔ)的服務(wù)器。其能達(dá)到數(shù)據(jù)平均分布和查找定位準(zhǔn)確的要求,并且優(yōu)點(diǎn)是算法簡單,存取時(shí)的計(jì)算量都比較?。ㄔ跀?shù)據(jù)非常大時(shí)才會(huì)明顯)。
但其有一個(gè)致命缺點(diǎn),即一個(gè)服務(wù)器宕機(jī)后的影響很大,我們可以推算一下一臺(tái)服務(wù)器宕機(jī)后的影響:
原有數(shù)據(jù)大部分丟失:服務(wù)器數(shù)量減少一臺(tái),取模數(shù)減1導(dǎo)致取模值錯(cuò)亂,如果以前有N臺(tái)服務(wù)器,那么宕機(jī)后數(shù)據(jù)只有1/(n*(n-1))的數(shù)據(jù)能夠被準(zhǔn)確查找到。
負(fù)載無法均衡導(dǎo)致集體宕機(jī):如果沒有及時(shí)處理宕機(jī)的服務(wù)器,那么他的存儲(chǔ)任務(wù)將會(huì)被順序積累給它的下一個(gè)服務(wù)器,那么下一個(gè)服務(wù)器也會(huì)很快被壓致宕機(jī),如此一來,服務(wù)器組很快會(huì)集體宕機(jī)。
算法思想
一致性哈希算法是使用一定的哈希算法,將大量的數(shù)據(jù)平均映射到不同的存儲(chǔ)目標(biāo)上,在保證其查找準(zhǔn)確性的同時(shí),還要考慮其中一個(gè)存儲(chǔ)目標(biāo)失效時(shí),其他存儲(chǔ)目標(biāo)對(duì)其責(zé)任存儲(chǔ)內(nèi)容的負(fù)載均衡。
一致性哈希算法的實(shí)現(xiàn)思想不難理解,如圖:
1.用一定的哈希算法(哈希函數(shù)等)將一組服務(wù)器的多個(gè)(數(shù)目自己設(shè)定)節(jié)點(diǎn)隨機(jī)映射分散到0-232之間,由于其隨機(jī)分布,保證了其數(shù)據(jù)平均分布的特點(diǎn);
2.用同一算法計(jì)算要存儲(chǔ)數(shù)據(jù)的鍵,根據(jù)服務(wù)器節(jié)點(diǎn)確定其存儲(chǔ)的服務(wù)器結(jié)點(diǎn),由于每次用同一算法計(jì)算,所以得出的結(jié)果是相同的,使其查找定位準(zhǔn)確;
3.查找數(shù)據(jù)時(shí),再次用同一算法計(jì)算鍵,并查找服務(wù)器的數(shù)據(jù)結(jié)點(diǎn);
4.如果有一個(gè)服務(wù)器宕機(jī),消除其服務(wù)器結(jié)點(diǎn),并將數(shù)據(jù)放在下一個(gè)結(jié)點(diǎn)上,由于隨機(jī)節(jié)點(diǎn)位置的隨機(jī)性,所以數(shù)據(jù)被其他服務(wù)器平均負(fù)載,也就降低了宕機(jī)影響。
需要注意的是,這個(gè)環(huán)形空間只是一個(gè)虛擬空間,只是表示了服務(wù)器存儲(chǔ)的范圍和數(shù)據(jù)的落點(diǎn),在進(jìn)行存儲(chǔ)時(shí),我們還要通過查找到的落點(diǎn),將數(shù)據(jù)放入對(duì)應(yīng)的服務(wù)器進(jìn)行查改。
算法實(shí)現(xiàn)
編程語言我們使用PHP來實(shí)現(xiàn)一致性哈希算法:
我們主要用到以下函數(shù):
intcrc32(string$str)
生成str的32位循環(huán)冗余校驗(yàn)碼多項(xiàng)式。這通常用于檢查傳輸?shù)臄?shù)據(jù)是否完整。
stringsprintf(string$format[,mixed$args[,mixed$...]])
通過傳入的格式產(chǎn)生字符串的特定格式形態(tài)。
實(shí)現(xiàn)如下:
classConsistance
protected$num=24;//設(shè)定每一個(gè)服務(wù)器的節(jié)點(diǎn)數(shù),數(shù)量越多,宕機(jī)時(shí)服務(wù)器負(fù)載就會(huì)分布得越平均,但也增大數(shù)據(jù)查找消耗。
protected$nodes=array();//當(dāng)前服務(wù)器組的結(jié)點(diǎn)列表。
//計(jì)算一個(gè)數(shù)據(jù)的哈希值,用以確定位置
publicfunctionmake_hash($data)
returnsprintf('%u',crc32($data));
//遍歷當(dāng)前服務(wù)器組的節(jié)點(diǎn)列表,確定需要存儲(chǔ)/查找的服務(wù)器
publicfunctionset_loc($data)
$loc=self::make_hash($data);
foreach($this-nodesas$key=$val)
if($loc=$key)
return$val;
//添加一個(gè)服務(wù)器,將其結(jié)點(diǎn)添加到服務(wù)器組的節(jié)點(diǎn)列表內(nèi)。
publicfunctionadd_host($host)
for($i=0;$i$this-$i++)
$key=sprintf('%u',crc32($host.'_'.$i));
$this-nodes[$key]=$host;
ksort($this-nodes);//對(duì)結(jié)點(diǎn)排序,這樣便于查找。
//刪除一個(gè)服務(wù)器,并將其對(duì)應(yīng)節(jié)點(diǎn)從服務(wù)器組的節(jié)點(diǎn)列表內(nèi)移除。
publicfunctionremove_host($host)
for($i=0;$i$this-$i++)
$key=sprintf('%u',crc32($host.'_'.$i));
unset($this-nodes[$key]);
}
我們用以下代碼進(jìn)行測試:
結(jié)果如下:
總結(jié)
算法的實(shí)現(xiàn)到此,我們還可以對(duì)算法進(jìn)行優(yōu)化,如在服務(wù)器數(shù)量和每個(gè)服務(wù)器節(jié)點(diǎn)數(shù)都很多的情況下,對(duì)查找結(jié)點(diǎn)的過程進(jìn)行優(yōu)化,因?yàn)榕判蚝玫?,可以用二分法進(jìn)行查找,加快查詢效率,這些,仁智各見吧。
另外,雖然nginx服務(wù)器有一致性算法的插件,memcache和redis也都有相應(yīng)的插件,MySQL的中間件有相應(yīng)的集成,但是了解一
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 項(xiàng)目成功因素研究試題及答案
- 公共服務(wù)政策的公平性與效率分析試題及答案
- 軟件設(shè)計(jì)師考試定制化復(fù)習(xí)試題及答案
- 計(jì)算機(jī)軟件測試在環(huán)境政策評(píng)估中的應(yīng)用試題及答案
- 計(jì)算機(jī)軟件測試中的常見問題試題及答案
- 公共政策的全球視野與本土化探討試題及答案
- 軟件設(shè)計(jì)師考試技能提升路線試題及答案
- 現(xiàn)代公共政策理論框架試題及答案
- 如何建立健全公共政策的決策制度試題及答案
- 項(xiàng)目團(tuán)隊(duì)沖突處理技巧試題及答案
- 2025年砂石常規(guī)檢測試題及答案
- 機(jī)械設(shè)計(jì)制造及其自動(dòng)化畢業(yè)論文-溫室用小型電動(dòng)旋拼機(jī)設(shè)計(jì)
- 2025人教版七年級(jí)下冊生物期末學(xué)業(yè)質(zhì)量檢測試卷(含答案)
- 教師職業(yè)道德與專業(yè)發(fā)展知到智慧樹章節(jié)測試課后答案2024年秋魯東大學(xué)
- 品質(zhì)管理品質(zhì)部管理制度
- 非標(biāo)機(jī)械設(shè)備工廠項(xiàng)目績效獎(jiǎng)激勵(lì)方案2023年
- 養(yǎng)老護(hù)理員職業(yè)道德及行為規(guī)范
- 貴州省遵義市(2024年-2025年小學(xué)六年級(jí)語文)部編版質(zhì)量測試((上下)學(xué)期)試卷及答案
- 《綠色建筑咨詢服務(wù)》課件
- T∕CEC 208-2019 電動(dòng)汽車充電設(shè)施信息安全技術(shù)規(guī)范
- 《輪胎濕地操縱穩(wěn)定性主觀評(píng)價(jià)方法》
評(píng)論
0/150
提交評(píng)論