PHP實(shí)現(xiàn)普通hash分布式算法簡(jiǎn)單示例
本文實(shí)例講述了PHP實(shí)現(xiàn)普通hash分布式算法。分享給大家供大家參考,具體如下:
<?php
/*
* 普通hash分布式算法
* @param $key
* @return int
*/
class Hash{
protected $_serverList = array();
public function __construct($_serverList){
if(is_array($_serverList)){
$this->_serverList = $_serverList;
}else{
return false;
}
}
//通過(guò)hash算法返回一個(gè)整數(shù)值
protected function myHash($key){
$md5 = substr(md5($key),0,8);
$seed = 31; //種子值
$hash=0;
for($i=0;$i<8;$i++){
$hash = $hash*$seed+ord($md5{$i}); //ord 返回ascii值
$i++;
}
return $hash&0x7FFFFFFF; //0x7FFFFFFF表示最大值
}
public function getServer($key){
$servers = $this->_serverList;
$rs = $servers[$this->myHash($key)%(count($servers))];
return $rs;
}
}
$servers = array(
array('host'=>'192.168.1.1','port'=>6397),
array('host'=>'192.168.1.2','port'=>6397),
array('host'=>'192.168.1.3','port'=>6397),
array('host'=>'192.168.1.4','port'=>6397),
array('host'=>'192.168.1.5','port'=>6397),
array('host'=>'192.168.1.6','port'=>6397),
array('host'=>'192.168.1.7','port'=>6397),
);
$key = 'TheKey'.rand(0,99999);
$value = 'TheValue';
$hash = new Hash($servers);
if($hash){
$server = $hash->getServer($key);
// $memcached = new Memcached($sc);
// $memcached->set($key,$value);
}
?>
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é)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP Socket網(wǎng)絡(luò)操作類定義與用法示例
這篇文章主要介紹了PHP Socket網(wǎng)絡(luò)操作類定義與用法,結(jié)合實(shí)例形式分析了php socket網(wǎng)絡(luò)操作類的定義及結(jié)合ajax發(fā)送查詢請(qǐng)求等相關(guān)使用技巧,需要的朋友可以參考下2017-08-08
PHP函數(shù)之error_reporting(E_ALL ^ E_NOTICE)詳細(xì)說(shuō)明
在看帝國(guó)cms的connect.php是發(fā)現(xiàn)第一句是error_reporting(E_ALL ^ E_NOTICE);以前也沒(méi)注意過(guò)這個(gè)語(yǔ)句,知道是設(shè)置錯(cuò)誤提示的,但不清楚具體怎樣設(shè)置使用。下面從網(wǎng)上摘抄了些東西,總結(jié)了一下。2011-07-07
利用PHP擴(kuò)展vld查看PHP opcode操作步驟
首先下載最新版vld擴(kuò)展接下來(lái)編譯安裝vld擴(kuò)展最后將生成的vld.so復(fù)制到extension_dir目錄下然后修改php.ini文件接下來(lái)創(chuàng)建test.php文件,感興趣的你可以參考下本文2013-03-03
深入eAccelerator與memcached的區(qū)別詳解
本篇文章是對(duì)eAccelerator與memcached的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
在PHP中檢查PHP文件是否有語(yǔ)法錯(cuò)誤的方法
在網(wǎng)上找了一下。剛開(kāi)始以為 token_get_all()函數(shù)能處理語(yǔ)法錯(cuò)誤的問(wèn)題,結(jié)果發(fā)現(xiàn),它只是做簡(jiǎn)單的詞法分析。沒(méi)有辦法。后來(lái)到論壇上去問(wèn)了一下2009-12-12
在ThinkPHP6中使用mysql進(jìn)行分頁(yè)查詢的實(shí)現(xiàn)代碼
隨著互聯(lián)網(wǎng)的快速發(fā)展,web應(yīng)用程序的開(kāi)發(fā)也越來(lái)越復(fù)雜,而分頁(yè)查詢是web應(yīng)用程序中常見(jiàn)的功能之一,thinkphp6是一個(gè)web框架,可以幫助開(kāi)發(fā)人員快速開(kāi)發(fā)應(yīng)用程序,在本文中,我們將討論如何在thinkphp6中使用mysql進(jìn)行分頁(yè)查詢,需要的朋友可以參考下2024-07-07
如何利用php array_multisort函數(shù) 對(duì)數(shù)據(jù)庫(kù)結(jié)果進(jìn)行復(fù)雜排序
本篇文章是對(duì)用php array_multisort函數(shù)對(duì)數(shù)據(jù)庫(kù)結(jié)果進(jìn)行復(fù)雜排序進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06

