欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一致性哈希算法以及其PHP實(shí)現(xiàn)詳細(xì)解析

 更新時(shí)間:2013年08月24日 09:39:41   作者:  
以下是對(duì)用PHP實(shí)現(xiàn)一致性哈希算法進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下

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

典型的應(yīng)用場(chǎng)景是: 有N臺(tái)服務(wù)器提供緩存服務(wù),需要對(duì)服務(wù)器進(jìn)行負(fù)載均衡,將請(qǐng)求平均分發(fā)到每臺(tái)服務(wù)器上,每臺(tái)機(jī)器負(fù)責(zé)1/N的服務(wù)。

常用的算法是對(duì)hash結(jié)果取余數(shù) (hash() mod N):對(duì)機(jī)器編號(hào)從0到N-1,按照自定義的hash()算法,對(duì)每個(gè)請(qǐng)求的hash()值按N取模,得到余數(shù)i,然后將請(qǐng)求分發(fā)到編號(hào)為i的機(jī)器。但這樣的算法方法存在致命問(wèn)題,如果某一臺(tái)機(jī)器宕機(jī),那么應(yīng)該落在該機(jī)器的請(qǐng)求就無(wú)法得到正確的處理,這時(shí)需要將當(dāng)?shù)舻姆?wù)器從算法從去除,此時(shí)候會(huì)有(N-1)/N的服務(wù)器的緩存數(shù)據(jù)需要重新進(jìn)行計(jì)算;如果新增一臺(tái)機(jī)器,會(huì)有N /(N+1)的服務(wù)器的緩存數(shù)據(jù)需要進(jìn)行重新計(jì)算。對(duì)于系統(tǒng)而言,這通常是不可接受的顛簸(因?yàn)檫@意味著大量緩存的失效或者數(shù)據(jù)需要轉(zhuǎn)移)。那么,如何設(shè)計(jì)一個(gè)負(fù)載均衡策略,使得受到影響的請(qǐng)求盡可能的少呢?

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

1、Consistent Hashing算法描述

下面以Memcached中的Consisten Hashing算法為例說(shuō)明。
由于hash算法結(jié)果一般為unsigned int型,因此對(duì)于hash函數(shù)的結(jié)果應(yīng)該均勻分布在[0,232-1]間,如果我們把一個(gè)圓環(huán)用232 個(gè)點(diǎn)來(lái)進(jìn)行均勻切割,首先按照hash(key)函數(shù)算出服務(wù)器(節(jié)點(diǎn))的哈希值, 并將其分布到0~232的圓上。

用同樣的hash(key)函數(shù)求出需要存儲(chǔ)數(shù)據(jù)的鍵的哈希值,并映射到圓上。然后從數(shù)據(jù)映射到的位置開(kāi)始順時(shí)針查找,將數(shù)據(jù)保存到找到的第一個(gè)服務(wù)器(節(jié)點(diǎn))上。

 Consistent Hashing原理示意圖

新增一個(gè)節(jié)點(diǎn)的時(shí)候,只有在圓環(huán)上新增節(jié)點(diǎn)逆時(shí)針?lè)较虻牡谝粋€(gè)節(jié)點(diǎn)的數(shù)據(jù)會(huì)受到影響。刪除一個(gè)節(jié)點(diǎn)的時(shí)候,只有在圓環(huán)上原來(lái)刪除節(jié)點(diǎn)順時(shí)針?lè)较虻牡谝粋€(gè)節(jié)點(diǎn)的數(shù)據(jù)會(huì)受到影響,因此通過(guò)Consistent Hashing很好地解決了負(fù)載均衡中由于新增節(jié)點(diǎn)、刪除節(jié)點(diǎn)引起的hash值顛簸問(wèn)題。

 Consistent Hashing添加服務(wù)器示意圖

虛擬節(jié)點(diǎn)(virtual nodes):之所以要引進(jìn)虛擬節(jié)點(diǎn)是因?yàn)樵诜?wù)器(節(jié)點(diǎn))數(shù)較少的情況下(例如只有3臺(tái)服務(wù)器),通過(guò)hash(key)算出節(jié)點(diǎn)的哈希值在圓環(huán)上并不是均勻分布的(稀疏的),仍然會(huì)出現(xiàn)各節(jié)點(diǎn)負(fù)載不均衡的問(wèn)題。虛擬節(jié)點(diǎn)可以認(rèn)為是實(shí)際節(jié)點(diǎn)的復(fù)制品(replicas),本質(zhì)上與實(shí)際節(jié)點(diǎn)實(shí)際上是一樣的(key并不相同)。引入虛擬節(jié)點(diǎn)后,通過(guò)將每個(gè)實(shí)際的服務(wù)器(節(jié)點(diǎn))數(shù)按照一定的比例(例如200倍)擴(kuò)大后并計(jì)算其hash(key)值以均勻分布到圓環(huán)上。在進(jìn)行負(fù)載均衡時(shí)候,落到虛擬節(jié)點(diǎn)的哈希值實(shí)際就落到了實(shí)際的節(jié)點(diǎn)上。由于所有的實(shí)際節(jié)點(diǎn)是按照相同的比例復(fù)制成虛擬節(jié)點(diǎn)的,因此解決了節(jié)點(diǎn)數(shù)較少的情況下哈希值在圓環(huán)上均勻分布的問(wèn)題。

 

虛擬節(jié)點(diǎn)對(duì)Consistent Hashing結(jié)果的影響

從上圖可以看出,在節(jié)點(diǎn)數(shù)為10個(gè)的情況下,每個(gè)實(shí)際節(jié)點(diǎn)的虛擬節(jié)點(diǎn)數(shù)為實(shí)際節(jié)點(diǎn)的100-200倍的時(shí)候,結(jié)果還是很均衡的。

第3段中有這些文字:“但這樣的算法方法存在致命問(wèn)題,如果某一臺(tái)機(jī)器宕機(jī),那么應(yīng)該落在該機(jī)器的請(qǐng)求就無(wú)法得到正確的處理,這時(shí)需要將當(dāng)?shù)舻姆?wù)器從算法從去除,此時(shí)候會(huì)有(N-1)/N的服務(wù)器的緩存數(shù)據(jù)需要重新進(jìn)行計(jì)算;”

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

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

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

【consistent hashing 的辦法】
上面提到的 hash 取模,模數(shù)取的比較小,一般是負(fù)載的數(shù)量,而 consistent hashing 的本質(zhì)是將模數(shù)取的比較大,為 2的32次方減1,即一個(gè)最大的 32 位整數(shù)。然后,就可以從容的安排數(shù)據(jù)導(dǎo)向了,那個(gè)圖還是挺直觀的。
以下部分為一致性哈希算法的一種PHP實(shí)現(xiàn)。點(diǎn)擊下載

相關(guān)文章

  • 利用PHP計(jì)算有多少小于當(dāng)前數(shù)字的數(shù)字方法示例

    利用PHP計(jì)算有多少小于當(dāng)前數(shù)字的數(shù)字方法示例

    這篇文章主要給大家介紹了關(guān)于利用PHP計(jì)算有多少小于當(dāng)前數(shù)字的數(shù)字的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 字母順序顛倒而單詞順序不變的php代碼

    字母順序顛倒而單詞順序不變的php代碼

    一個(gè)英文語(yǔ)句怎樣把它的每個(gè)單詞的字母順序顛倒而單詞順序不變?
    2010-08-08
  • php計(jì)算兩個(gè)整數(shù)的最大公約數(shù)常用算法小結(jié)

    php計(jì)算兩個(gè)整數(shù)的最大公約數(shù)常用算法小結(jié)

    這篇文章主要介紹了php計(jì)算兩個(gè)整數(shù)的最大公約數(shù)常用算法,實(shí)例總結(jié)了求最大公約數(shù)的三種常用方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-03-03
  • 使用PHP實(shí)現(xiàn)生成HTML靜態(tài)頁(yè)面

    使用PHP實(shí)現(xiàn)生成HTML靜態(tài)頁(yè)面

    在PHP網(wǎng)站開(kāi)發(fā)中為了網(wǎng)站推廣和SEO等需要,需要對(duì)網(wǎng)站進(jìn)行全站或局部靜態(tài)化處理,PHP生成靜態(tài)HTML頁(yè)面有多種方法,比如利用PHP模板、緩存等實(shí)現(xiàn)頁(yè)面靜態(tài)化,今天就以PHP實(shí)例教程形式討論P(yáng)HP生成靜態(tài)頁(yè)面的方法。
    2015-11-11
  • php相當(dāng)簡(jiǎn)單的分頁(yè)類

    php相當(dāng)簡(jiǎn)單的分頁(yè)類

    代碼比較簡(jiǎn)單,學(xué)習(xí)php類的朋友,可以看下
    2008-10-10
  • PHP使用flock實(shí)現(xiàn)文件加鎖的方法

    PHP使用flock實(shí)現(xiàn)文件加鎖的方法

    這篇文章主要介紹了PHP使用flock實(shí)現(xiàn)文件加鎖的方法,實(shí)例分析了flock文件鎖的使用技巧,需要的朋友可以參考下
    2015-07-07
  • PHP判斷變量是否為0的方法

    PHP判斷變量是否為0的方法

    這篇文章主要介紹了PHP判斷變量是否為0的方法,需要的朋友可以參考下
    2014-02-02
  • PHP中實(shí)現(xiàn)中文字符進(jìn)制轉(zhuǎn)換原理分析

    PHP中實(shí)現(xiàn)中文字符進(jìn)制轉(zhuǎn)換原理分析

    中文字符編碼研究系列第四期,PHP實(shí)現(xiàn)中文字符進(jìn)制轉(zhuǎn)換原理分析,主要討論中文漢字轉(zhuǎn)換為十進(jìn)制和十六進(jìn)制的方法,并掌握轉(zhuǎn)換原理應(yīng)用于實(shí)際開(kāi)發(fā)。本文以GBK編碼字符為例,討論GBK編碼的字符轉(zhuǎn)換原理
    2011-12-12
  • php知道與問(wèn)問(wèn)的采集插件代碼

    php知道與問(wèn)問(wèn)的采集插件代碼

    看過(guò)一個(gè)百度小偷的網(wǎng)站也達(dá)到了pr6。收錄十萬(wàn)多!! 在經(jīng)過(guò) 薦禮啦 四十天的實(shí)踐之后 發(fā)現(xiàn)百度對(duì)這個(gè)確實(shí)挺友好的。
    2010-10-10
  • PHP 實(shí)現(xiàn)多服務(wù)器共享 SESSION 數(shù)據(jù)

    PHP 實(shí)現(xiàn)多服務(wù)器共享 SESSION 數(shù)據(jù)

    稍大一些的網(wǎng)站,通常都會(huì)有好幾個(gè)服務(wù)器,每個(gè)服務(wù)器運(yùn)行著不同功能的模塊,使用不同的二級(jí)域名,而一個(gè)整體性強(qiáng)的網(wǎng)站,用戶系統(tǒng)是統(tǒng)一的,即一套用戶名、密碼在整個(gè)網(wǎng)站的各個(gè)模塊中都是可以登錄使用的。
    2009-08-08

最新評(píng)論