一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

一致性哈希算法以及其PHP實現詳細解析

在做服務器負載均衡時候可供選擇的負載均衡的算法有很多,包括:  輪循算法(Round Robin)、哈希算法(HASH)、最少連接算法(Least Connection)、響應速度算法(Response Time)、加權法(Weighted )等。其中哈希算法是最為常用的算法.

典型的應用場景是: 有N臺服務器提供緩存服務,需要對服務器進行負載均衡,將請求平均分發到每臺服務器上,每臺機器負責1/N的服務。

常用的算法是對hash結果取余數 (hash() mod N):對機器編號從0到N-1,按照自定義的hash()算法,對每個請求的hash()值按N取模,得到余數i,然后將請求分發到編號為i的機器。但這樣的算法方法存在致命問題,如果某一臺機器宕機,那么應該落在該機器的請求就無法得到正確的處理,這時需要將當掉的服務器從算法從去除,此時候會有(N-1)/N的服務器的緩存數據需要重新進行計算;如果新增一臺機器,會有N /(N+1)的服務器的緩存數據需要進行重新計算。對于系統而言,這通常是不可接受的顛簸(因為這意味著大量緩存的失效或者數據需要轉移)。那么,如何設計一個負載均衡策略,使得受到影響的請求盡可能的少呢?

在Memcached、Key-Value Store、Bittorrent DHT、LVS中都采用了Consistent Hashing算法,可以說Consistent Hashing 是分布式系統負載均衡的首選算法。

1、Consistent Hashing算法描述

下面以Memcached中的Consisten Hashing算法為例說明。
由于hash算法結果一般為unsigned int型,因此對于hash函數的結果應該均勻分布在[0,232-1]間,如果我們把一個圓環用232 個點來進行均勻切割,首先按照hash(key)函數算出服務器(節點)的哈希值, 并將其分布到0~232的圓上。

用同樣的hash(key)函數求出需要存儲數據的鍵的哈希值,并映射到圓上。然后從數據映射到的位置開始順時針查找,將數據保存到找到的第一個服務器(節點)上。

 Consistent Hashing原理示意圖

新增一個節點的時候,只有在圓環上新增節點逆時針方向的第一個節點的數據會受到影響。刪除一個節點的時候,只有在圓環上原來刪除節點順時針方向的第一個節點的數據會受到影響,因此通過Consistent Hashing很好地解決了負載均衡中由于新增節點、刪除節點引起的hash值顛簸問題。

 Consistent Hashing添加服務器示意圖

虛擬節點(virtual nodes):之所以要引進虛擬節點是因為在服務器(節點)數較少的情況下(例如只有3臺服務器),通過hash(key)算出節點的哈希值在圓環上并不是均勻分布的(稀疏的),仍然會出現各節點負載不均衡的問題。虛擬節點可以認為是實際節點的復制品(replicas),本質上與實際節點實際上是一樣的(key并不相同)。引入虛擬節點后,通過將每個實際的服務器(節點)數按照一定的比例(例如200倍)擴大后并計算其hash(key)值以均勻分布到圓環上。在進行負載均衡時候,落到虛擬節點的哈希值實際就落到了實際的節點上。由于所有的實際節點是按照相同的比例復制成虛擬節點的,因此解決了節點數較少的情況下哈希值在圓環上均勻分布的問題。

 

虛擬節點對Consistent Hashing結果的影響

從上圖可以看出,在節點數為10個的情況下,每個實際節點的虛擬節點數為實際節點的100-200倍的時候,結果還是很均衡的。

第3段中有這些文字:“但這樣的算法方法存在致命問題,如果某一臺機器宕機,那么應該落在該機器的請求就無法得到正確的處理,這時需要將當掉的服務器從算法從去除,此時候會有(N-1)/N服務器的緩存數據需要重新進行計算;”

為何是 (N-1)/N 呢?解釋如下:

比如有 3 臺機器,hash值 1-6 在這3臺上的分布就是:
host 1: 1 4
host 2: 2 5
host 3: 3 6
如果掛掉一臺,只剩兩臺,模數取 2 ,那么分布情況就變成:
host 1: 1 3 5
host 2: 2 4 6

可以看到,還在數據位置不變的只有2個: 1,2,位置發生改變的有4個,占共6個數據的比率是 4/6 = 2/3這樣的話,受影響的數據太多了,勢必太多的數據需要重新從 DB 加載到 cache 中,嚴重影響性能

【consistent hashing 的辦法】
上面提到的 hash 取模,模數取的比較小,一般是負載的數量,而 consistent hashing 的本質是將模數取的比較大,為 2的32次方減1,即一個最大的 32 位整數。然后,就可以從容的安排數據導向了,那個圖還是挺直觀的。
以下部分為一致性哈希算法的一種php實現。點擊下載

php技術一致性哈希算法以及其PHP實現詳細解析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 成人www视频 | 中文字幕日本精品一区二区三区 | 91久久精品在这里色伊人6882 | 亚洲成人77777 | 一级风流片a级国产 | 亚洲天堂一区二区在线观看 | 久久久夜间小视频 | 人人添人人澡人人澡人人人人 | 美女久久精品 | 一木道一二三区精品 | 免费视频一区二区三区四区 | 一区二区三区在线视频播放 | 欧美福利| 国产精品极品美女自在线看免费一区二区 | 精品久久久久久婷婷 | 日本一区二区三区中文字幕 | www.狠狠| 婷婷激情四射网 | 国产精品拍自在线观看 | 国产成人lu在线视频 | 91麻豆视频网站 | 色老板免费在线观看 | 五月激情综合网 | 黄色小视频免费 | 久久66久这里精品99 | 免费观看色 | 伊人四虎 | 成人sq视频在线观看网站 | 91无套极品外围在线播放 | 色播视频在线 | 色婷婷激情五月综合 | 天天操91 | 日本精品高清一区二区不卡 | 国产成人亚洲欧美激情 | 欧美激情午夜 | 亚洲一二四区性毛片1在线 亚洲一级黄色毛片 | 中文字幕在线一区二区在线 | 欧美太黄太色视频在线观看 | 97精品国产自在现线免费观看 | 欧美人体极品大胆露私 | 91精品一区二区三区在线观看 |