日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

如何用PHP實現(xiàn)分布算法之一致性哈希算法

瀏覽:50日期:2022-09-07 11:30:37
目錄傳統(tǒng)算法缺陷算法思想算法實現(xiàn)總結(jié)傳統(tǒng)算法缺陷

對于服務(wù)器分布,我們要考慮的東西有如下三點:數(shù)據(jù)平均分布,查找定位準(zhǔn)確,降低宕機(jī)影響。

傳統(tǒng)算法一般是將數(shù)據(jù)的鍵用算法映射出數(shù)字,對其用服務(wù)器數(shù)量取模,并根據(jù)結(jié)果選擇要存儲的服務(wù)器。其能達(dá)到數(shù)據(jù)平均分布和查找定位準(zhǔn)確的要求,并且優(yōu)點是算法簡單,存取時的計算量都比較小(在數(shù)據(jù)非常大時才會明顯)。

但其有一個致命缺點,即一個服務(wù)器宕機(jī)后的影響很大,我們可以推算一下一臺服務(wù)器宕機(jī)后的影響:

原有數(shù)據(jù)大部分丟失:服務(wù)器數(shù)量減少一臺,取模數(shù)減1導(dǎo)致取模值錯亂,如果以前有N臺服務(wù)器,那么宕機(jī)后數(shù)據(jù)只有1/(n*(n-1))的數(shù)據(jù)能夠被準(zhǔn)確查找到。 負(fù)載無法均衡導(dǎo)致集體宕機(jī):如果沒有及時處理宕機(jī)的服務(wù)器,那么他的存儲任務(wù)將會被順序積累給它的下一個服務(wù)器,那么下一個服務(wù)器也會很快被壓致宕機(jī),如此一來,服務(wù)器組很快會集體宕機(jī)。算法思想

一致性哈希算法是使用一定的哈希算法,將大量的數(shù)據(jù)平均映射到不同的存儲目標(biāo)上,在保證其查找準(zhǔn)確性的同時,還要考慮其中一個存儲目標(biāo)失效時,其他存儲目標(biāo)對其責(zé)任存儲內(nèi)容的負(fù)載均衡。

一致性哈希算法的實現(xiàn)思想不難理解,如圖:

如何用PHP實現(xiàn)分布算法之一致性哈希算法

1.用一定的哈希算法(哈希函數(shù)等)將一組服務(wù)器的多個(數(shù)目自己設(shè)定)節(jié)點隨機(jī)映射分散到0-232之間,由于其隨機(jī)分布,保證了其數(shù)據(jù)平均分布的特點;

2.用同一算法計算要存儲數(shù)據(jù)的鍵,根據(jù)服務(wù)器節(jié)點確定其存儲的服務(wù)器結(jié)點,由于每次用同一算法計算,所以得出的結(jié)果是相同的,使其查找定位準(zhǔn)確;

3.查找數(shù)據(jù)時,再次用同一算法計算鍵,并查找服務(wù)器的數(shù)據(jù)結(jié)點;

4.如果有一個服務(wù)器宕機(jī),消除其服務(wù)器結(jié)點,并將數(shù)據(jù)放在下一個結(jié)點上,由于隨機(jī)節(jié)點位置的隨機(jī)性,所以數(shù)據(jù)被其他服務(wù)器平均負(fù)載,也就降低了宕機(jī)影響。

需要注意的是,這個環(huán)形空間只是一個虛擬空間,只是表示了服務(wù)器存儲的范圍和數(shù)據(jù)的落點,在進(jìn)行存儲時,我們還要通過查找到的落點,將數(shù)據(jù)放入對應(yīng)的服務(wù)器進(jìn)行查改。

算法實現(xiàn)

編程語言我們使用PHP來實現(xiàn)一致性哈希算法:

我們主要用到以下函數(shù):

int crc32 ( string $str )生成 str 的 32 位循環(huán)冗余校驗碼多項式。這通常用于檢查傳輸?shù)臄?shù)據(jù)是否完整。

string sprintf ( string $format [, mixed $args [, mixed $... ]] ) 通過傳入的格式產(chǎn)生字符串的特定格式形態(tài)。

實現(xiàn)如下:

class Consistance{ protected $num=24; //設(shè)定每一個服務(wù)器的節(jié)點數(shù),數(shù)量越多,宕機(jī)時服務(wù)器負(fù)載就會分布得越平均,但也增大數(shù)據(jù)查找消耗。 protected $nodes=array(); //當(dāng)前服務(wù)器組的結(jié)點列表。 //計算一個數(shù)據(jù)的哈希值,用以確定位置 public function make_hash($data) {return sprintf(’%u’,crc32($data)); } //遍歷當(dāng)前服務(wù)器組的節(jié)點列表,確定需要存儲/查找的服務(wù)器 public function set_loc($data) {$loc=self::make_hash($data);foreach ($this->nodes as $key => $val){ if($loc<=$key) {return $val; }} } //添加一個服務(wù)器,將其結(jié)點添加到服務(wù)器組的節(jié)點列表內(nèi)。 public function add_host($host) {for($i=0;$i<$this->num;$i++){ $key=sprintf(’%u’,crc32($host.’_’.$i)); $this->nodes[$key]=$host; }ksort($this->nodes);//對結(jié)點排序,這樣便于查找。 } //刪除一個服務(wù)器,并將其對應(yīng)節(jié)點從服務(wù)器組的節(jié)點列表內(nèi)移除。 public function remove_host($host) {for($i=0;$i<$this->num;$i++){ $key=sprintf(’%u’,crc32($host.’_’.$i)); unset($this->nodes[$key]);} }}

我們用以下代碼進(jìn)行測試:

如何用PHP實現(xiàn)分布算法之一致性哈希算法

結(jié)果如下:

如何用PHP實現(xiàn)分布算法之一致性哈希算法

總結(jié)

算法的實現(xiàn)到此,我們還可以對算法進(jìn)行優(yōu)化,如在服務(wù)器數(shù)量和每個服務(wù)器節(jié)點數(shù)都很多的情況下,對查找結(jié)點的過程進(jìn)行優(yōu)化,因為排序好的,可以用二分法進(jìn)行查找,加快查詢效率,這些,仁智各見吧。

另外,雖然nginx服務(wù)器有一致性算法的插件,memcache和redis也都有相應(yīng)的插件,MySQL的中間件有相應(yīng)的集成,但是了解一致性哈希算法也很有意義。而且,我們也可以對其靈活使用,如對文件等進(jìn)行分布式管理等等。

以上就是如何用PHP實現(xiàn)分布算法之一致性哈希算法的詳細(xì)內(nèi)容,更多關(guān)于用PHP實現(xiàn)分布算法之一致性哈希算法的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: PHP
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩视频免费看| 国产乱人伦丫前精品视频| 精品一区二区三区在线观看视频| 久久国产精品免费精品3p| 麻豆高清免费国产一区| 国产精品久久久久久久免费观看| 日韩大片在线播放| 美女少妇全过程你懂的久久| 在线视频精品| 久久精品成人| 综合一区在线| 国产经典一区| 999精品在线| 中文字幕成人| 精品美女视频| 免费在线观看一区| 久久久久久免费视频| 视频一区二区三区中文字幕| 欧美影院视频| 欧美日韩免费看片| 亚洲一二av| 水蜜桃久久夜色精品一区| 99成人在线| 国产欧美在线| 精品资源在线| 一本色道久久精品| 国产精久久一区二区| 欧美成人国产| 欧美经典一区| 久久国产精品99国产| 国产精品毛片久久久| 免费成人网www| 久久gogo国模啪啪裸体| 黄色av日韩| 成人午夜毛片| 天堂va在线高清一区| jizzjizz中国精品麻豆| 综合激情网...| 成人久久一区| 日韩欧美高清一区二区三区| 麻豆精品蜜桃| 国产精品成人国产| 国产精品日韩久久久| 国产a亚洲精品| 少妇精品在线| 欧美精品一二| 日本在线啊啊| 国产亚洲精品美女久久久久久久久久| 啪啪国产精品| 精品视频一二| 日韩二区在线观看| 国产亚洲一级| 日韩一区自拍| 国产精品久久久久久久久久齐齐 | 亚洲一区黄色| 天堂中文av在线资源库| 欧美啪啪一区| 伊人精品久久| 黑丝一区二区三区| 日韩深夜视频| 欧美国产中文高清| 日本va欧美va瓶| 夜久久久久久| 欧美中文一区二区| 国产精品免费不| 亚洲影院天堂中文av色| 欧美理论视频| 久久精品免费一区二区三区| 国产一区丝袜| 国产精品1luya在线播放| 日韩福利视频一区| 亚洲精品影院在线观看| 激情91久久| 免费av一区二区三区四区| a国产在线视频| 色婷婷色综合| 手机在线电影一区| 成人精品高清在线视频| 精品精品国产三级a∨在线| 国产乱码精品| 日本中文字幕不卡| 日韩精品免费视频一区二区三区| 一区二区国产精品| 一区二区高清| 亚洲91网站| 91成人小视频| 国产欧美自拍| 国产精品片aa在线观看| 久久激情av| 国产精成人品2018| 精品国产鲁一鲁****| 国产中文欧美日韩在线| 成人影视亚洲图片在线| 在线天堂中文资源最新版| 韩国女主播一区二区三区| 蜜桃精品视频| 中文字幕人成乱码在线观看 | 亚洲18在线| 日韩精品一页| 国产精品男女| 岛国av在线网站| 91精品一区二区三区综合| 99久久久久| 在线国产一区二区| 久久先锋影音| 69精品国产久热在线观看| 欧美日韩 国产精品| 国产欧美日韩一区二区三区在线| 国产精品最新自拍| 91日韩免费| 午夜久久美女| 婷婷五月色综合香五月| 欧美日韩一区二区三区四区在线观看 | 日韩在线观看一区二区| 日韩在线播放一区二区| 日本一区二区三区视频在线看 | 亚洲激情欧美| 亚洲久久视频| 国产精品xvideos88| 国产一区二区三区亚洲| 色综合www| 免费精品视频最新在线| 欧美精品三级在线| 日韩电影免费在线观看| 国产模特精品视频久久久久| 亚州精品视频| 日韩成人精品一区| 蜜桃伊人久久| 麻豆成人91精品二区三区| 国产99久久久国产精品成人免费| 日本亚洲不卡| 中文字幕人成乱码在线观看 | 国产精品a级| 亚洲欧美综合| 国产探花在线精品| 精品国产aⅴ| 99综合视频| 久久精品天堂| 首页亚洲欧美制服丝腿| 久久精品五月| 在线综合亚洲| 精品一区二区三区视频在线播放| 婷婷精品进入| 久久精品国产网站| 亚洲精品123区| 精品伊人久久| 综合干狼人综合首页| 97精品国产| 亚洲精品一二| 伊人久久大香线蕉av不卡| 中文字幕亚洲精品乱码| 97人人精品| 日韩精品第二页| 久久国产影院| 麻豆成人在线观看| 亚洲一区二区免费在线观看| 午夜av不卡| 国产乱人伦丫前精品视频| 日韩网站在线| 国产精品亚洲一区二区三区在线观看| 日韩精品成人在线观看| 欧美高清不卡| 麻豆成全视频免费观看在线看| 亚洲精品系列| 一区在线免费观看| 国产精品xx| 国产精品欧美三级在线观看| 性欧美精品高清| 九九精品调教| 国产91在线播放精品| 欧美日韩伊人| 免费视频最近日韩| 国产综合精品一区| 日韩久久视频| 精品美女视频| 国产精品第十页| 日本高清久久| 日韩中文字幕麻豆| 午夜欧美理论片| 99精品综合| 国产成人久久精品麻豆二区| 日本免费一区二区视频| 亚洲最新av| 爽好多水快深点欧美视频| 久久精品国内一区二区三区水蜜桃| 精品一区二区三区四区五区| 国产美女亚洲精品7777| 91精品啪在线观看国产爱臀| 亚洲精品字幕| 亚洲一二av| 视频一区二区三区中文字幕| 1024精品久久久久久久久| 蜜桃视频欧美| 国产高清一区| 亚洲欧美视频| 国产农村妇女精品一二区| 不卡在线一区| 国产女优一区| 久久不射中文字幕| 中文字幕视频精品一区二区三区|