主頁 > 知識庫 > PHP實(shí)現(xiàn)的服務(wù)器一致性hash分布算法示例

PHP實(shí)現(xiàn)的服務(wù)器一致性hash分布算法示例

熱門標(biāo)簽:代理打電話機(jī)器人 桂陽公司如何做地圖標(biāo)注 宿州正規(guī)外呼系統(tǒng)軟件 合肥企業(yè)外呼系統(tǒng)線路 企業(yè)400電話辦理多少費(fèi)用 神龍斗士電話機(jī)器人 電信外呼系統(tǒng)多少錢一個月 太原400電話申請流程 萍鄉(xiāng)商鋪地圖標(biāo)注

本文實(shí)例講述了PHP實(shí)現(xiàn)的服務(wù)器一致性hash分布算法。分享給大家供大家參考,具體如下:

?php
/**
 * 對服務(wù)器進(jìn)行一致性hash分布算法
 */
class HashRing
{
  private $servers = array();
  private $nodeList = array();
  private $nodeHashList = array();
  private $nodeTotalNum = 0;
  private $virtualNodeNum = 32;
  private $keyHash = '';
  public function __construct($servers)
  {
    $this->servers = $servers;
    foreach ($servers as $server) {
      for ($i = 0; $i  $this->virtualNodeNum; $i++) {
        $this->nodeList[sprintf("%u", crc32($server.'-'.$i))] = array($server, $i);
      }
    }
    ksort($this->nodeList);
    $this->nodeHashList = array_keys($this->nodeList);
  }
  private function getNodeIndex($key)
  {
    $this->keyHash = sprintf("%u", crc32($key));
    if ($this->keyHash > end($this->nodeHashList)) {
      $this->keyHash = $this->keyHash % end($this->nodeHashList);
    }
    if ($this->keyHash = reset($this->nodeHashList)) {
      return 0;
    }
    $this->nodeTotalNum = count($this->nodeHashList);
    return $this->binaryChopIndex(0, $this->nodeTotalNum);
  }
  private function binaryChopIndex($l=0, $r=0)
  {
    if ($l  $r) {
      $avg = intval(($l+$r) / 2);
      if ($this->nodeHashList[$avg] == $this->keyHash) {
        return $avg;
      } elseif ($this->keyHash  $this->nodeHashList[$avg]  ($avg > 0)) {
        return $this->binaryChopIndex($l, $avg-1);
      } else {
        return $this->binaryChopIndex($avg+1, $r);
      }
    } else {
      return $l;
    }
  }
  public function getServersByKey($key, $num=1)
  {
    $index = $this->getNodeIndex($key);
    $server = $this->nodeList[$this->nodeHashList[$index]];
    if ($num == 1) {
      return $server[0];
    }
    if ($num >= count($this->servers)) {
      $num = count($this->servers);
    }
    $result = array($server[0]);
    for ($i=$index+1; true; $i++) {
      if ($i >= $this->nodeTotalNum) {
        $i = 0;
      }
      $nextServer = $this->nodeList[$this->nodeHashList[$i]];
      if (!in_array($nextServer[0], $result)) {
        $result[] = $nextServer[0];
      }
      if (count($result) == $num) {
        break;
      }
    }
    return $result;
  }
}
//示例
$servers = array(
  '127.0.0.1:11211',
  '127.0.0.1:11212',
  '127.0.0.1:11213',
  '127.0.0.1:11214',
  '127.0.0.1:11215'
);
$obj = new HashRing($servers);
$servers = $obj->getServersByKey('testkey', 2);
print_r($servers);
echo "\n";

運(yùn)行結(jié)果:

Array
(
    [0] => 127.0.0.1:11214
    [1] => 127.0.0.1:11211
)

PS:這里再為大家提供2款hash相關(guān)在線工具供大家參考使用:

在線散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt

在線MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php加密方法總結(jié)》、《PHP編碼與轉(zhuǎn)碼操作技巧匯總》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》及《php正則表達(dá)式用法總結(jié)》

希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • PHP哈希表實(shí)現(xiàn)算法原理解析
  • PHP實(shí)現(xiàn)的一致性哈希算法完整實(shí)例
  • PHP內(nèi)核探索:哈希表碰撞攻擊原理
  • PHP中創(chuàng)建和驗(yàn)證哈希的簡單方法實(shí)探
  • php內(nèi)核解析:PHP中的哈希表
  • php-perl哈希算法實(shí)現(xiàn)(times33哈希算法)
  • PHP 5.5 創(chuàng)建和驗(yàn)證哈希最簡單的方法詳解
  • 一致性哈希算法以及其PHP實(shí)現(xiàn)詳細(xì)解析
  • 如何用PHP實(shí)現(xiàn)分布算法之一致性哈希算法

標(biāo)簽:太原 白銀 鄂州 辛集 崇左 廊坊 綏化 衡陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP實(shí)現(xiàn)的服務(wù)器一致性hash分布算法示例》,本文關(guān)鍵詞  PHP,實(shí)現(xiàn),的,服務(wù)器,一致性,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP實(shí)現(xiàn)的服務(wù)器一致性hash分布算法示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP實(shí)現(xiàn)的服務(wù)器一致性hash分布算法示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章