search
Homephp教程PHP源码Redis负载均衡封装
Redis负载均衡封装May 25, 2016 pm 05:05 PM
php

RedisClient.php 

<?php
/**
 * This is a Redis exntend class
 */

class RedisClient
{
	public static $instance = NULL;
	public static $linkHandle = array();
	//construct:connect redis
	public function __construct($configs)
	{
		$this->initRedis($configs);
	}

	/**
	 * Get a instance of MyRedisClient
	 *
	 * @param string $key
	 * @return object
	 */
    static function getInstance($configs)
    {
		if (!self::$instance) {
			self::$instance = new self($configs);
		}
		return self::$instance;
    }
    
    /**
     * 初始化Redis
     */
    private function initRedis($conf){
    	foreach ($conf[&#39;master&#39;] as $k=>$v){  
    		$obj = new Redis();
    		if($obj->pconnect($v[&#39;host&#39;],$v[&#39;port&#39;])){
    			$obj->auth($v[&#39;auth&#39;]);
    			self::$linkHandle[&#39;master&#39;][] = $obj;
    			
    		}
    	}
    	
    	foreach ($conf[&#39;slave&#39;] as $k=>$v){
    		$obj = new Redis();
    		if($obj->pconnect($v[&#39;host&#39;],$v[&#39;port&#39;])){
    			$obj->auth($v[&#39;auth&#39;]);
    			self::$linkHandle[&#39;slave&#39;][] = $obj;
    		}
    	}
    }
    
    /**
     * 获得redis Resources
     * 
     * @param $key	 redis存的key/或随机值
     * @param string $tag	master/slave
     */
    public function getRedis($key=null,$tag=&#39;master&#39;){
    	empty($key)?$key = uniqid():&#39;&#39;;
    	$arr_index = $this->getHostByHash($key,count(self::$linkHandle[$tag])); //获得相应主机的数组下标
    	return self::$linkHandle[$tag][$arr_index];
    }
    
    /**
     * 随机取出主机
     * @param $key		$变量key值
     * @param $n		主机数
     * @return string
     */
	private function getHostByHash($key,$n){
		if($n<2) return 0;
		$u = strtolower($key);
		$id = sprintf("%u", crc32($key));
		
		$m = base_convert( intval(fmod($id, $n)), 10, $n);
		return $m{0};
	}
	
	/**
	 * 关闭连接
	 * pconnect 连接是无法关闭的
	 *  
	 * @param int $flag 关闭选择 0:关闭 Master 1:关闭 Slave 2:关闭所有
	 * @return boolean
	 */
	public function close($flag=2){
		switch($flag){
			// 关闭 Master
			case 0:
				foreach (self::$linkHandle[&#39;master&#39;] as $var){
					$var->close();
				}
				break;
				// 关闭 Slave
			case 1:
				foreach (self::$linkHandle[&#39;slave&#39;] as $var){
					$var->close();
				}
				break;
				// 关闭所有
			case 1:
				$this->close(0);
				$this->close(1);
				break;
		}
		return true;
	}
	
	//-------------------------------------------------------------------------------
	
	public function hGetAll($key){
		return $this->getRedis($key,&#39;slave&#39;)->hGetAll($key);
	}
	
	/**
	 * redis 字符串(String) 类型
	 * 将key和value对应。如果key已经存在了,它会被覆盖,而不管它是什么类型。
	 * @param $key
	 * @param $value
	 * @param $exp 过期时间
	 */
	public function set($key,$value,$exp=0){
		$redis = $this->getRedis($key);
		$redis->set($key,$value);
		!empty($exp) && $redis->expire($key,$exp);
	}
	/**
	 * 返回key的value。如果key不存在,返回特殊值nil。如果key的value不是string,就返回错误,因为GET只处理string类型的values。
	 * @param $key
	 */
	public function get($key){
		return $this->getRedis($key,&#39;slave&#39;)->get($key);
	}
	/**
	 * KEYS pattern
	 * 查找所有匹配给定的模式的键
	 * @param $is_key   默认是一个非正则表达试,使用模糊查询
	 * @param $key
	 */
	public function keys($key,$is_key=true){
		if ($is_key) {
			return $this->getRedis($key,&#39;slave&#39;)->keys("*$key*");
		}
		return $this->getRedis($key,&#39;slave&#39;)->keys("$key");
	}
	
	/**
	 * 批量填充HASH表。不是字符串类型的VALUE,自动转换成字符串类型。使用标准的值。NULL值将被储存为一个空的字符串。
	 * 
	 * 可以批量添加更新 value,key 不存在将创建,存在则更新值
	 * 
	 * @param  $key
	 * @param  $fieldArr
	 * @return
	 * 如果命令执行成功,返回OK。
	 * 当key不是哈希表(hash)类型时,返回一个错误。
	 */
	public function hMSet($key,$fieldArr){
		return $this->getRedis($key)->hmset($key,$fieldArr);
	}
	/**
	 * 向已存在于redis里的Hash 添加多个新的字段及值
	 * 
	 * @param  $key			redis 已存在的key
	 * @param  $field_arr	kv形数组
	 */
	public function hAddFieldArr($key,$field_arr){
		foreach ($field_arr as $k=>$v){
			$this->hAddFieldOne($key, $k, $v);
		}
	}
	
	/**
	 * 向已存在于redis里的Hash 添加一个新的字段及值
	 * @param  $key
	 * @param  $field_name
	 * @param  $field_value
	 * @return bool
	 */
	public function hAddFieldOne($key,$field_name,$field_value){
		return $this->getRedis($key)->hsetnx($key,$field_name,$field_value);
	}
	
	/**
	 * 向Hash里添加多个新的字段或修改一个已存在字段的值
	 * @param $key
	 * @param $field_arr
	 */
	public function hAddOrUpValueArr($key,$field_arr){
		foreach ($field_arr as $k=>$v){
			$this->hAddOrUpValueOne($key, $k, $v);
		}
	}
	/**
	 * 向Hash里添加多个新的字段或修改一个已存在字段的值
	 * @param  $key
	 * @param  $field_name
	 * @param  $field_value
	 * @return boolean 
	 * 1 if value didn&#39;t exist and was added successfully, 
	 * 0 if the value was already present and was replaced, FALSE if there was an error.
	 */
	public function hAddOrUpValueOne($key,$field_name,$field_value){
		return $this->getRedis($key)->hset($key,$field_name,$field_value);
	}
	
	/**
	 *  删除哈希表key中的多个指定域,不存在的域将被忽略。
	 * @param $key
	 * @param $field_arr
	 */
	public function hDel($key,$field_arr){
		foreach ($field_arr as $var){
			$this->hDelOne($key,$var);
		}
	}
	
	/**
	 * 删除哈希表key中的一个指定域,不存在的域将被忽略。
	 * 
	 * @param $key
	 * @param $field
	 * @return BOOL TRUE in case of success, FALSE in case of failure
	 */
	public function hDelOne($key,$field){
		return $this->getRedis($key)->hdel($key,$field);
	}
	
	/**
	 * 重命名key
	 * 
	 * @param $oldkey
	 * @param $newkey
	 */
	public function renameKey($oldkey,$newkey){
		return $this->getRedis($oldkey)->rename($oldkey,$newkey);
	}
	
	/**
	 * 删除一个或多个key
	 * @param $keys
	 */
	public function delKey($keys){
		if(is_array($keys)){
			foreach ($keys as $key){
				$this->getRedis($key)->del($key);
			}
		}else {
			$this->getRedis($key)->del($key);
		}
	}
	/**
	 * 添加一个字符串值到LIST容器的顶部(左侧),如果KEY不存在,曾创建一个LIST容器,如果KEY存在并且不是一个LIST容器,那么返回FLASE。
	 * 
	 * @param unknown $key
	 * @param unknown $val
	 */
	public function lPush($key,$val){
		$this->getRedis($key)->lPush($key,$val);
	}
	
	/**
	 * 返回LIST顶部(左侧)的VALUE,并且从LIST中把该VALUE弹出。
	 * @param unknown $key
	 */
	public function lPop($key){
		$this->getRedis($key)->lPop($key);
	}


	/**
	 * 批量的添加多个key 到redis
	 * @param $fieldArr
	 */
	public function mSetnx($fieldArr){

		$this->getRedis()->mSetnx($fieldArr);
	}
}
?>

2. [代码]redis配置及使用方法    

$config_redis = array();
$config_redis[&#39;master&#39;] = array(
		array(&#39;host&#39;=>&#39;127.0.0.1&#39;,
				&#39;auth&#39;=>&#39;123456&#39;,
				&#39;port&#39;=>&#39;6379&#39;
		)
);

$config_redis[&#39;slave&#39;] = array(
		array(&#39;host&#39;=>&#39;127.0.0.1&#39;,
				&#39;auth&#39;=>&#39;123456&#39;,
				&#39;port&#39;=>&#39;6379&#39;
		)
);

//使用方式
$redis = RedisClient::getInstance(config_redis);

                   

                   

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
php怎么把负数转为正整数php怎么把负数转为正整数Apr 19, 2022 pm 08:59 PM

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

php怎么实现几秒后执行一个函数php怎么实现几秒后执行一个函数Apr 24, 2022 pm 01:12 PM

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php怎么除以100保留两位小数php怎么除以100保留两位小数Apr 22, 2022 pm 06:23 PM

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php字符串有没有下标php字符串有没有下标Apr 24, 2022 am 11:49 AM

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php怎么根据年月日判断是一年的第几天php怎么根据年月日判断是一年的第几天Apr 22, 2022 pm 05:02 PM

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php怎么替换nbsp空格符php怎么替换nbsp空格符Apr 24, 2022 pm 02:55 PM

方法:1、用“str_replace("&nbsp;","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\&nbsp\;||\xc2\xa0)/","其他字符",$str)”语句。

php怎么读取字符串后几个字符php怎么读取字符串后几个字符Apr 22, 2022 pm 08:31 PM

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

php怎么判断有没有小数点php怎么判断有没有小数点Apr 20, 2022 pm 08:12 PM

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Hot Tools

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.