码迷,mamicode.com
首页 > 编程语言 > 详细

一致性哈希算法PHP测试片段

时间:2017-08-31 12:59:43      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:utf8   char   ret   amp   服务器   排序   hash   ace   rtp   

<?php
header(‘Content-type: text/html; charset=utf8‘);
# 抽象接口
interface hash{
public function _hash($str);
}
interface distribution{
public function lookup($key);
}

# hash 算法实例
class Consistent implements hash,distribution {
protected $point_num = 64;
protected $posi = array();
protected $server;

#计算一个hash值
public function _hash($str){
return sprintf(‘%u‘,crc32($str));
}

# 计算key分布到的服务器
public function lookup($key){
foreach($this->posi as $k=>$v){
if ($this->_hash($key) <= $k ){
$this->server = $v;
break;
}
}
return $this->server;
}

# 添加服务节点
public function addServer($server){
for ($i=1;$i<=$this->point_num;$i++){
$this->posi[$this->_hash($server.‘_‘.$i)] = $server;
}
$this->sortPosi();
}

#排序定位点
public function sortPosi(){
ksort($this->posi);
}

#打印定位点
public function printPosi(){
echo ‘<pre>‘;
print_r($this->posi);
}
}

$hash = new Consistent();
$hash->addServer(‘a‘);
$hash->addServer(‘b‘);
$hash->addServer(‘c‘);

#test hash
$key = ‘abc‘;
$server = $hash->lookup($key);
echo $key.‘对应的服务器是:‘.$Server.‘ &nbsp;&nbsp;对应的hash值是:‘.$hash->_hash($key);
echo ‘<hr />‘;
$hash->printPosi();

一致性哈希算法PHP测试片段

标签:utf8   char   ret   amp   服务器   排序   hash   ace   rtp   

原文地址:http://www.cnblogs.com/shengy/p/7457068.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!