码迷,mamicode.com
首页 > Web开发 > 详细

基于php的一个最简单的memcache的分布式算法

时间:2014-06-20 10:36:06      阅读:213      评论:0      收藏:0      [点我收藏+]

标签:php   web服务器   分布式   算法   

首先,核心函数是这个

function mHash($key){

$md=substr(md5($key),0,8);

$seed=31;

  $hash=0;

for($i=0;$i<8;$i++){

$hash=$hash*$seed+ord($md5{$i});

}

return $hash & 0x7FFFFFFF;

}

class HashServer{

private $serverlist;

private $issorted=false;

function addServer($server){

$hash=mHash($server);

if(!isset($this->serverlist[$hash])){

$this->serverlist[$hash]=$server;

}

return true;

}

function getKeyServer($key){

$hash=mHash($key);

if(!this->issorted){

ksort($this->serverlist,SORT_NUMERIC);

}

foreach($this->serverlist as $k=>$v){

if($hash>=$k) return $v;
}

return $this->serverlist[count($this->serverlist)-1];

}

}



//下面开始测试

   $hs=new HashServer();

   $hs->addServer(‘192.168.1.1‘);

   $hs->addServer(‘192.168.1.2‘);

   $hs->addServer(‘192.168.1.3‘);

   echo $hs->getKeyServer(‘key1‘);

   echo $hs->getKeyServer(‘key2‘);

   echo $hs->getKeyServer(‘key3‘);

基于php的一个最简单的memcache的分布式算法,布布扣,bubuko.com

基于php的一个最简单的memcache的分布式算法

标签:php   web服务器   分布式   算法   

原文地址:http://blog.csdn.net/wmda999/article/details/28595205

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