PHP实现的服务器一致性hash分布算法示例


Posted in PHP onAugust 09, 2018

本文实例讲述了PHP实现的服务器一致性hash分布算法。分享给大家供大家参考,具体如下:

<?php
/**
 * 对服务器进行一致性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";

运行结果:

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

PHP 相关文章推荐
ecshop 订单确认中显示省市地址信息的方法
Mar 15 PHP
PHP 多维数组排序(usort,uasort)
Jun 30 PHP
深入PHP获取随机数字和字母的方法详解
Jun 06 PHP
php实现文件编码批量转换
Mar 10 PHP
PHP ignore_user_abort函数详细介绍和使用实例
Jul 15 PHP
PHP session文件独占锁引起阻塞问题解决方法
May 12 PHP
PHP加密解密函数详解
Oct 28 PHP
Laravel5.* 打印出执行的sql语句的方法
Jul 24 PHP
PHP实现权限管理功能示例
Sep 22 PHP
php ajax confirm 删除实例详解
Mar 06 PHP
php获取目录下所有文件及目录(多种方法)(推荐)
May 14 PHP
浅谈如何提高PHP代码的质量
May 28 PHP
PHP检查端口是否可以被绑定的方法示例
Aug 09 #PHP
php对象工厂类完整示例
Aug 09 #PHP
php闭包中使用use声明变量的作用域实例分析
Aug 09 #PHP
php生成二维码不保存服务器还有下载功能的实现代码
Aug 09 #PHP
PHP命令Command模式用法实例分析
Aug 08 #PHP
PHP耦合设计模式实例分析
Aug 08 #PHP
thinkPHP框架整合tcpdf插件操作示例
Aug 07 #PHP
You might like
漫威DC即将合作联动,而双方早已经秘密开始
2020/04/09 欧美动漫
初学者入门:细述PHP4的核心Zend
2006/09/05 PHP
PHP在线生成二维码代码(google api)
2013/06/03 PHP
注意:php5.4删除了session_unregister函数
2013/08/05 PHP
php中current、next与reset函数用法实例
2014/11/17 PHP
jquery ajax对特殊字符进行转义防止js注入使用示例
2013/11/21 Javascript
浅谈jquery中delegate()与live()
2015/06/22 Javascript
jquery+CSS实现的水平布局多级网页菜单效果
2015/08/24 Javascript
以JavaScript来实现WordPress中的二级导航菜单的方法
2015/12/14 Javascript
JavaScript数据绑定实现一个简单的 MVVM 库
2016/04/08 Javascript
JS实现搜索关键词的智能提示功能
2017/07/07 Javascript
vue实现点击展开点击收起效果
2018/04/27 Javascript
Vue2.0 v-for filter列表过滤功能的实现
2018/09/07 Javascript
vue框架下部署上线后刷新报404问题的解决方案(推荐)
2019/04/03 Javascript
vue-cli3项目展示本地Markdown文件的方法
2019/06/07 Javascript
layer.open回调获取弹出层参数的实现方法
2019/09/10 Javascript
跟老齐学Python之编写类之四再论继承
2014/10/11 Python
Python下的subprocess模块的入门指引
2015/04/16 Python
Python中支持向量机SVM的使用方法详解
2017/12/26 Python
Python pycharm 同时加载多个项目的方法
2019/01/17 Python
对Python3之进程池与回调函数的实例详解
2019/01/22 Python
解决python replace函数替换无效问题
2020/01/18 Python
Python re正则表达式元字符分组()用法分享
2020/02/10 Python
Python库skimage绘制二值图像代码实例
2020/04/10 Python
基于HTML5 WebGL的3D机房的示例
2018/03/16 HTML / CSS
Python如何定义一个函数
2015/09/01 面试题
创伤外科专业推荐信范文
2013/11/19 职场文书
追悼会子女答谢词
2014/01/28 职场文书
个人实习生的自我评价
2014/02/16 职场文书
安全教育月活动总结
2014/05/05 职场文书
班主任与学生安全责任书
2014/07/25 职场文书
工作疏忽、懈怠的检讨书
2014/09/11 职场文书
税务干部个人整改措施思想汇报
2014/10/10 职场文书
个人年终总结范文
2015/03/09 职场文书
2019个人工作态度自我评价
2019/04/24 职场文书
星际争霸:毕姥爷vs解冻03
2022/04/01 星际争霸