一致性Hash分布算法实例

本文介绍使用PHP实现一致性Hash算法。

创建一个FlexiHash类,他有两个成员变量和三个方法:

$serverlist:保存服务器列表。

$isSorted:记录服务器列表是否已经排过序。

addServer:添加一个服务器到服务器列表中;

removeServer:从服务器列表中删除一个服务器;

lookup:在当前的服务器中寻找合适的服务器存放数据。

【示例】:

<span style="font-family:Microsoft YaHei;font-size:18px;"><?
       class FlexiHash{
              private $serverList= array();
              private $isSorted =FALSE;
             
              public functionaddServer($server){
                     $hash =mHash($server);
                     if(!isset($this-> serverList[$hash])){
                            $this-> serverList[$hash] = $server;
                     }
                     $this ->isSorted = FALSE;
                     return TRUE;
              }
              functionremoveServer($server){
                     $hash =mHash($server);
                     if(!isset($this-> serverList[$hash])){
                            $this-> serverList[$hash] = $server;
                     }
                     $this ->isSorted = FALSE;
                     return TRUE;
              }
              functionlookup($key){
                     $hash =mHash($key);
                     if(!$this-> isSorted){
                            krsort($this-> serverList,SORT_NUMERIC);
                            $this-> isSorted = TRUE;
                            foreach($this-> serverList as $pos => $server){
                                   if($hash>= $pos) return $server;
                            }
                            return$this -> serverList[count($this -> serverList) -1];
                     }
              }
               
       }
       $server = new FlexiHash();
       $server ->addServer("192.168.1.1");
       $server ->addServer("192.168.1.2");
       $server ->addServer("192.168.1.3");
       $server ->addServer("192.168.1.4");
       $server ->addServer("192.168.1.5");
       echo "save key1 inserver:".$server->lookup('key1');
       echo "save key2 inserver:".$server->lookup('key2');
       echo"+++++++++++++++++++++++++++++++++++++++++++++";
       $server ->removeServer("192.168.1.4");
       echo "save key1 inserver:".$server->lookup('key1');
       echo "save key2 inserver:".$server->lookup('key2');
       echo"+++++++++++++++++++++++++++++++++++++++++++++";
       $server ->addServer("192.168.1.6");
       echo "save key1 inserver:".$server->lookup('key1');
       echo "save key2 inserver:".$server->lookup('key2');
       echo"+++++++++++++++++++++++++++++++++++++++++++++";    </span>


       

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值