色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

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

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

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

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

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

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

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

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

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

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

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

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

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

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

算法實現(xiàn)

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

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

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

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

實現(xiàn)如下:

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

我們用以下代碼進行測試:

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

結果如下:

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

總結

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

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

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

標簽: PHP
相關文章:
主站蜘蛛池模板: 一本色道久久88亚洲综合 | 日韩区在线 | 男人和女人的做刺激性视频 | 日本理论在线播放 | 亚洲综合一区二区精品久久 | 一区二区中文字幕亚洲精品 | 一区二区三区视频 | 久久久久18 | 中文字幕最新中文字幕中文字幕 | www.99精品视频在线播放 | 国产高清无专砖区2021 | 久久免费高清视频 | 久久久久国产精品免费看 | 日韩三级免费观看 | 久久一本色系列综合色 | 91成人免费视频 | 国产精品热久久毛片 | 久久国产成人精品麻豆 | 成年女人在线视频 | 高清欧美一级在线观看 | 亚洲男同可播放videos | 国产精品毛片在线大全 | 亚洲欧美一级视频 | 亚洲高清国产一线久久 | 欧美一区二区三区视视频 | 久久久久久久久久免费视频 | 1769视频在线观看国产 | 亚洲三级a | 亚洲人成在线影院 | 欧美精品一级 | 亚洲成人免费视频 | 国产精品19p | 国产美女在线一区二区三区 | 美女视频黄视大全视频免费网址 | 亚洲综合在线观看视频 | 中文字幕在线观看一区二区三区 | 久草网站在线观看 | 国产乱子视频 | 国产精品永久免费自在线观看 | 国产精品久久久久久久久久直 | 久久九九精品一区二区 |