Redis基础操作类

简单的redis操作类

类版本:1.00
功能说明:
封装了几个比较常用的操作:设置值、获取值、设置值到期时间、订阅频道等,还有一个过期值回调功能

这里主要说明以下过期值回调功能:
一般项目中,特别是有支付情节的项目中,我们要实现一个订单2小时还没有支付的话,就关闭订单的一个功能。就可以用这个过期值回调。但是这个过期值回调的话,只回调键名。所以可以在设置键值的时候将订单号设置在键中,这样就可以完美的获取到过期的订单号了

部署说明:
将类文件解压至Mb/tools文件夹下即可。


使用说明:
  1. 初始化__construct($host = '127.0.0.1', $port = 6379)参数:主机地址、端口
  2. 设置有效期的键值setex($key, $time, $val)参数:$key=键, $time=过期时间(秒), $val=值
  3. 设置键值set($key, $val)参数:$key=键, $val=值
  4. 取值get($key)参数:$key=键
  5. 设置到期时间expire($key = null, $time = 0)参数:$key=键, $time=过期时间(秒)
  6. 解决Redis客户端订阅时候超时情况setOption()
  7. 过期回调keyCallbackFunc($c)参数:$c=控制器
普通使用演示:
class testController extends Mb{
	
	public function index(){
		$redis = t('Redis');
		$res = $redis->setex('name',3600,'ZOSphp');
		var_dump($res);
		$res = $redis->get('name');
		var_dump($res);
		
		$res = $redis->set('title','超轻量级框架');
		var_dump($res);
		
		$res = $redis->expire('title', 3600);
		var_dump($res);
		
	}
	
}
订单超时、活动过期解决方案:

服务端:
/* 控制器 ZOSphp 超轻量级框架 */
class redisController extends Mb{
	
	//__init 函数会在控制器被创建时自动运行用于初始化工作,如果您要使用它,请按照以下格式编写代码即可:
	private $redis;
    	public $dbName = 'order_list';
	public function __init(){
		$this->redis = t('Redis');
	}
	
	public function index(){
		while($this->redis){
            $this->redis->setOption();
            echo "服务启动成功\n";
            $this->redis->keyCallbackFunc($this);
        }
	}
	
	public function ExpirationNotice($key){//此方法函数必须存在
        $keyarr = explode('-',$key);
        if(count($keyarr) >=2 && $keyarr[0] == 'OrderID'){//如果有多个参数自行修改判断
            $updateres = $this->db->where('id = ? and state = 0',[$keyarr[1]])->update(['state'=>1]);//如果订单任未支付则关闭订单
            if($updateres && $this->db->rowCount() >=1){
                echo $keyarr[1].'订单已关闭'."\n";
            }else{
                echo $keyarr[1].'订单以支付或关闭失败'."\n";
            }
        }else{
            echo $key.'获取失败'."\n";
        }
    }
	
}
客户端:
/* 控制器 ZOSphp 超轻量级框架 */
class indexController extends Mb{
    
	public $dbName = 'order_list';
	
	public function index(){
		$redis = t('Redis');
		if($redis){
            for ($i=1; $i<=100; $i++){
                $resID = $this->db->add(['state'=>0]);//添加订单
                if($resID){
                    $extime = rand(10,60);//这里使用随机10~60秒到期时间,方便观察,实际使用中根据自己业务需求设置到期时间
                    $key = 'OrderID-'.$resID;
                    $redis->setex($key,$extime,1);
                }
            }
            var_dump($resID);
        }else{
            echo "connect Redis server failed";
        }
	}
	
	
}
启动服务端:
启动服务端之前,需要先修改以下redis的配置:

notify-keyspace-events 的参数为 “Ex”。x 代表了过期事件。notify-keyspace-events “Ex” 保存配置后,重启Redis服务,使配置生效。

63a9b93d9c196.jpg

服务端的文件名:redis.php,位置:项目控制器文件及内
在根目录创建一个:service.php(入口文件名可自定义),内容:
/**
 * Redis服务入口
 * @link      http://www.ZOSphp.com
 * @copyright Copyright (c) 2022-2032 
 * @author    友易
 * @version   1.0.0
**/
$_GET['s'] = 'redis/index';
include 'Mb/Mb.php';
然后进行启动,这里以宝塔为例,先在软件商店里安装一个进程守护管理器,然后添加守护进程即可:

63a9b7f380d8e.jpg

启动后当有执行时,就会有执行日志,而且进程守护,即使程序被系统杀掉了或者因为其他原因掉线了,也会自动重启

63a9b9957e3d8.jpg

下面再给大家发发以下redis的操作大全:


/*1.字符串String,键值对,创建更新同操作*/
$redis->setOption(Redis::OPT_PREFIX,'hf_');//设置表前缀为hf_
$redis->set('key',1);//设置key=aa value=1 [true]
$redis->mset($arr);//设置一个或多个键值[true]
$redis->setnx('key','value');//key=value,key存在返回false[|true]
$redis->get('key');//获取key [value]
$redis->mget($arr);//(string|arr),返回所查询键的值
$redis->del($key_arr);//(string|arr)删除key,支持数组批量删除【返回删除个数】
$redis->delete($key_str,$key2,$key3);//删除keys,[del_num]
$redis->getset('old_key','new_value');//先获得key的值,然后重新赋值,[old_value | false]
$redis->strlen('key');//获取当前key的长度
$redis->append('key','string');//把string追加到key现有的value中[追加后的个数]
$redis->incr('key');//自增1,如不存在key,赋值为1(只对整数有效,存储以10进制64位,redis中为str)[new_num | false]
$redis->incrby('key',$num);//自增$num,不存在为赋值,值需为整数[new_num | false]
$redis->decr('key');//自减1,[new_num | false]
$redis->decrby('key',$num);//自减$num,[ new_num | false]
$redis->setex('key',10,'value');//key=value,有效期为10秒[true]
$redis->keys('*'); //遍历所有的键名
/*2.列表List栈的结构,注意表头表尾,创建更新分开操作*/
$redis->lpush('key','value'); //增,将value值插入列表表头。
$redis->rpush('key','value');//增,只能将一个值value插入到列表key的表尾 [列表的长度 |false]
$redis->lInsert('key',Redis::AFTER,'value','new_value');//增,将值value插入到列表key当中,位于值value之前或之后。[new_len | false]
$redis->lpushx('key','value');//增,只能将一个值value插入到列表key的表头,不存在不创建 [列表的长度 |false]
$redis->rpushx('key','value');//增,只能将一个值value插入到列表key的表尾,不存在不创建 [列表的长度 |false]
$redis->lpop('key');//删,移除并返回列表key的头元素,[被删元素 | false]
$redis->rpop('key');//删,移除并返回列表key的尾元素,[被删元素 | false]
$redis->brpop('key',)//删,移除并返回列表key的尾元素。第二个参数表示等待时长,超过时长返回nil。
$redis->blpop('key',1); //删,移除并返回列表key的头元素。堵塞元素。[被删除元素||false]
$redis->lrem('key','value',0);//删,根据参数count的值,移除列表中与参数value相等的元素count=(0|-n表头向尾|+n表尾向头移除n个value) [被移除的数量 | 0]
$redis->ltrim('key',start,end);//删,列表修剪,保留(start,end)之间的值 [true|false]
$redis->lset('key',index,'new_v');//改,从表头数,将列表key下标为第index的元素的值为new_v, [true | false]
$redis->lindex('key',index);//查,返回列表key中,下标为index的元素[value|false]
$redis->lrange('key',0,-1);//查,(start,stop|0,-1)返回列表key中指定区间内的元素,区间以偏移量start和stop指定。[array|false]
$redis->llen('key');//返回列表key的长度,不存在key返回0, [ len | 0]
/*3.集合Set,没有重复的member,创建更新同操作*/
$redis->sadd('key','value1','value2','valuen');//增,改,将一个或多个member元素加入到集合key当中,已经存在于集合的member元素将被忽略。[insert_num]
$redis->srem('key','value1','value2','valuen');//删,移除集合key中的一个或多个member元素,不存在的member元素会被忽略 [del_num | false]
$redis->smembers('key');//查,返回集合key中的所有成员 [array | '']
$redis->sismember('key','member');//判断member元素是否是集合key的成员 [1 | 0]
$redis->spop('key');//删,移除并返回集合中的一个随机元素 [member | false]
$redis->srandmember('key');//查,返回集合中的一个随机元素 [member | false]
$redis->sinter('key1','key2','keyn');//查,返回所有给定集合的交集 [array | false]
$redis->sunion('key1','key2','keyn');//查,返回所有给定集合的并集 [array | false]
$redis->sdiff('key1','key2','keyn');//查,返回所有给定集合的差集 [array | false]
$redis->scard('key');//返回集合key的基数(集合中元素的数量)。[num | 0]
$redis->sMove('key1','key2','member');//移动,将member元素从key1集合移动到key2集合。[1 | 0]
/*4.有序集合Zset,没有重复的member,有排序顺序,创建更新同操作*/
$redis->zAdd('key',$score1,$member1,$scoreN,$memberN);//增,改,将一个或多个member元素及其score值加入到有序集key当中。[num | 0]
$redis->zrem('key','member1','membern');//删,移除有序集key中的一个或多个成员,不存在的成员将被忽略。[del_num | 0]
$redis->zscore('key','member');//查,通过值反拿权 [num | null]
$redis->zrange('key',$start,$stop);//查,通过(score从小到大)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]
$redis->zrevrange('key',$start,$stop);//查,通过(score从大到小)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]
$redis->zrangebyscore('key',$min,$max[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从小到大排)成员[array | null]
$redis->zrevrangebyscore('key',$max,$min[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从大到小排)成员[array | null]
$redis->zrank('key','member');//查,通过member值查(score从小到大)排名结果中的【member排序名次】[order | null]
$redis->zrevrank('key','member');//查,通过member值查(score从大到小)排名结果中的【member排序名次】[order | null]
$redis->ZINTERSTORE();//交集
$redis->ZUNIONSTORE();//差集
$redis->zcard('key');//返回集合key的基数(集合中元素的数量)。[num | 0]
$redis->zcount('key',0,-1);//返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0]
/*5.哈希Hash,表结构,创建更新同操作*/
$redis->hset('key','field','value');//增,改,将哈希表key中的域field的值设为value,不存在创建,存在就覆盖【1 | 0】
$redis->hget('key','field');//查,取值【value|false】
$arr = array('one'=>1,2,3);$arr2 = array('one',0,1);
$redis->hmset('key',$arr);//增,改,设置多值$arr为(索引|关联)数组,$arr[key]=field, [ true ]
$redis->hmget('key',$arr2);//查,获取指定下标的field,[$arr | false]
$redis->hgetall('key');//查,返回哈希表key中的所有域和值。[当key不存在时,返回一个空表]
$redis->hkeys('key');//查,返回哈希表key中的所有域。[当key不存在时,返回一个空表]
$redis->hvals('key');//查,返回哈希表key中的所有值。[当key不存在时,返回一个空表]
$redis->hdel('key',$arr2);//删,删除指定下标的field,不存在的域将被忽略,[num | false]
$redis->hexists('key','field');//查看hash中是否存在field,[1 | 0]
$redis->hincrby('key','field',$int_num);//为哈希表key中的域field的值加上量(+|-)num,[new_num | false]
$redis->hlen('key');//返回哈希表key中域的数量。[ num | 0]
其他操作
/*1.连接*/
$redis =newRedis();
$redis->connect('127.0.0.1',6379,1);//短链接,本地host,端口为6379,超过1秒放弃链接
$redis->open('127.0.0.1',6379,1);//短链接(同上)
$redis->pconnect('127.0.0.1',6379,1);//长链接,本地host,端口为6379,超过1秒放弃链接
$redis->popen('127.0.0.1',6379,1);//长链接(同上)
$redis->auth('password');//登录验证密码,返回【true | false】
$redis->select(0);//选择redis库,0~15 共16个库
$redis->close();//释放资源
$redis->ping();//检查是否还再链接,[+pong]
$redis->ttl('key');//查看失效时间[-1 | timestamps]
$redis->persist('key');//移除失效时间[ 1 | 0]
$redis->sort('key',[$array]);//返回或保存给定列表、集合、有序集合key中经过排序的元素,$array为参数limit等!【配合$array很强大】 [array|false]
/*2.其他*/
$redis->dbSize();//返回当前库中的key的个数
$redis->flushAll();//清空整个redis[总true]
$redis->flushDB();//清空当前redis库[总true]
$redis->save();//同?把数据存储到磁盘-dump.rdb[true]
$redis->bgsave();//异步把数据存储到磁盘-dump.rdb[true]
$redis->info();//查询当前redis的状态 [verson:2.4.5....]
$redis->lastSave();//上次存储时间key的时间[timestamp]
$redis->watch('key','keyn');//监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 [true]
$redis->unwatch('key','keyn');//取消监视一个(或多个) key [true]
$redis->multi(Redis::MULTI);//开启事务,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。
$redis->multi(Redis::PIPELINE);//开启管道,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。
$redis->exec();//执行所有事务块内的命令,;【事务块内所有命令的返回值,按命令执行的先后顺序排列,当操作被打断时,返回空值 false】
$redis->expire('key',10);//设置失效时间[true | false]
$redis->move('key',15);//把当前库中的key移动到15库中[0|1]

如果对你有帮助

可以赞助并支持下作者哦,谢谢!