本文主要介绍了PHP操作Redis常用技巧,结合实例形式总结分析了php针对redis的连接、认证、string、hash等操作技巧与注意事项,需要的朋友可以参考
一、常用手册
/*1.Connection*/
$redis = new Redis(); $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->expire('key',10);//设置失效时间[true | false] $redis->move('key',15);//把当前库中的key移动到15库中[0|1] //string $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] //list $redis->llen('key');//返回列表key的长度,不存在key返回0, [ len | 0] //set $redis->scard('key');//返回集合key的基数(集合中元素的数量)。[num | 0] $redis->sMove('key1', 'key2', 'member');//移动,将member元素从key1集合移动到key2集合。[1 | 0] //Zset $redis->zcard('key');//返回集合key的基数(集合中元素的数量)。[num | 0] $redis->zcount('key',0,-1);//返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0] //hash $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]
/*3.Server*/
$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】
/*4.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]
/*5.List栈的结构,注意表头表尾,创建更新分开操作*/
$redis->lpush('key','value');//增,只能将一个值value插入到列表key的表头,不存在就创建 [列表的长度 |false] $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->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]
/*6.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]
/*7.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();//差集
/*8.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]
二、基本实例
1.Redis连接与认证
//连接参数:ip、端口、连接超时时间,连接成功返回true,否则返回false $ret = $redis->connect('127.0.0.1', 6379, 30); //密码认证:成功返回true,否则返回false $ret = $redis->auth('123456');
2.String操作
//设置键值:成功返回true,否则返回false $redis->set('mystr', 'Welcome!'); //获取键值:成功返回String类型键值,若key不存在或不是String类型则返回false $ret = $redis->get('mystr'); //从某个key所存储的字符串的指定偏移量开始,替换为另一指定字符串,成功返回替换后新字符串的长度。 $ret = $redis->setRange('mystr', 7, ' to Beijing!'); //获取存储在指定key中字符串的子字符串。 $ret = $redis->getRange('mystr', 0, 6); //设置新值,返回旧值:若key不存在则设置值,返回false $ret = $redis->getSet('mystr', 'hi man'); //一次设置多个键值对:成功返回true。 $ret = $redis->mset(['name' => 'jet', 'age' => 18]); //一次获取多个key的值:返回一个键值对数组,其中不存在的key值为false。 $ret = $redis->mget(['name', 'age']); //设置指定key的值及其过期时间,单位:秒。 //参数:键名,过期时间,键值。成功返回true。 $ret = $redis->setex('name', 10, 'jetwu'); //以毫秒为单位设置指定key的值和过期时间。成功返回true。 $ret = $redis->psetex('name', 10, 'jetwu'); //key的值不存在时,才为其设置值。key不存在且设置成功返回true,否则返回false。 $ret = $redis->setnx('name', 'boby'); //setnx命令的批量操作。只有在给定所有key都不存在的时候才能设置成功,只要其中一个key存在,所有key都无法设置成功。 $ret = $redis->msetnx(['country' => 'China', 'city' => 'Shenzhen']); //获取指定key存储的字符串的长度,key不存在返回0,不为字符串返回false。 $ret = $redis->strlen('name'); //将指定key存储的数字值增加1。若key不存在会先初始化为0再增加1,若key存储的不是整数值则返回false。成功返回key新值。 $ret = $redis->incr('age'); //给指定key存储的数字值增加指定增量值。 $ret = $redis->incrBy('age', 10); //给指定key存储的数字值增加指定浮点数增量。 $ret = $redis->incrByFloat('age', 1.5); //将指定key存储的数字值减一。 $ret = $redis->decr('age'); //将指定key存储的数字值减去指定减量值。 $ret = $redis->decrBy('age', 10); //为指定key追加值到原值末尾,若key不存在则相对于set()函数。 $ret = $redis->append('mystr', 'haha');
3.Hash操作
//为hash表中的字段赋值。成功返回1,失败返回0。若hash表不存在会先创建表再赋值,若字段已存在会覆盖旧值。 $ret = $redis->hSet('user', 'realname', 'jetwu'); //获取hash表中指定字段的值。若hash表不存在则返回false。 $ret = $redis->hGet('user', 'realname'); //查看hash表的某个字段是否存在,存在返回true,否则返回false。 $ret = $redis->hExists('user', 'realname'); //删除hash表的一个字段,不支持删除多个字段。成功返回1,否则返回0。 $ret = $redis->hDel('user', 'realname'); //同时设置某个hash表的多个字段值。成功返回true。 $ret = $redis->hMset('user', ['name' => 'jet', 'age' => 18]); //同时获取某个hash表的多个字段值。其中不存在的字段值为false。 $ret = $redis->hMget('user', ['name', 'age']); //获取某个hash表所有的字段和值。 $ret = $redis->hGetAll('user'); //获取某个hash表所有字段名。hash表不存在时返回空数组,key不为hash表时返回false。 $ret = $redis->hKeys('user'); //获取某个hash表所有字段值。 $ret = $redis->hVals('user'); //为hash表中不存在的字段赋值。若hash表不存在则先创建,若字段已存在则不做任何操作。设置成功返回true,否则返回false。 $ret = $redis->hSetNx('user', 'realname', 'jetwu'); //获取某个hash表的字段数量。若hash表不存在返回0,若key不为hash表则返回false。 $ret = $redis->hLen('user'); //为hash表中的指定字段加上指定增量值,若增量值为负数则相当于减法操作。若hash表不存在则先创建,若字段不存在则先初始化值为0再进行操作,若字段值为字符串则返回false。设置成功返回字段新值。 $ret = $redis->hIncrBy('user', 'age', 10); //为hash表中的指定字段加上指定浮点数增量值。 $ret = $redis->hIncrBy('user', 'age', 1.5);
4.List操作
//从list头部插入一个值。 $ret = $redis->lPush('city', 'guangzhou'); //从list尾部插入一个值。 $ret = $redis->rPush('city', 'guangzhou'); //获取列表指定区间中的元素。0表示列表第一个元素,-1表示最后一个元素,-2表示倒数第二个元素。 $ret = $redis->lrange('city', 0, -1);//查看队列所有元素 //将一个插入已存在的列表头部,列表不存在时操作无效。 $ret = $redis->lPushx('city', 'hangzhou'); //将一个或多个值插入已存在的列表尾部,列表不存在时操作无效。 $ret = $redis->rPushx('city', 'hangzhou'); //移除并返回列表的第一个元素,若key不存在或不是列表则返回false。 $ret = $redis->lPop('city'); //移除并返回列表的最后一个元素,若key不存在或不是列表则返回false。 $ret = $redis->rPop('city'); //移除并获取列表的第一个元素。如果列表没有元素则会阻塞列表直到等待超时或发现可弹出元素为止。 //参数:key,超时时间(单位:秒) //返回值:[0=>key,1=>value],超时返回[] $ret = $redis->blPop('city', 10); //移除并获取列表的最后一个元素。如果列表没有元素则会阻塞列表直到等待超时或发现可弹出元素为止。 //参数:key,超时时间(单位:秒) //返回值:[0=>key,1=>value],超时返回[] $ret = $redis->brPop('city', 10); //移除列表中最后一个元素,将其插入另一个列表头部,并返回这个元素。若源列表没有元素则返回false。 $ret = $redis->rpoplpush('city', 'city2'); //移除列表中最后一个元素,将其插入另一个列表头部,并返回这个元素。如果列表没有元素则会阻塞列表直到等待超时或发现可弹出元素为止。 //参数:源列表,目标列表,超时时间(单位:秒) //超时返回false $ret = $redis->brpoplpush('city', 'city2', 10); //返回列表长度。 $ret = $redis->lLen('city'); //通过索引获取列表中的元素。若索引超出列表范围则返回false。 $ret = $redis->lindex('city', 0); //通过索引设置列表中元素的值。若是索引超出范围,或对一个空列表进行lset操作,则返回false。 $ret = $redis->lSet('city', 2, 'changsha'); //在列表中指定元素前或后面插入元素。若指定元素不在列表中,或列表不存在时,不执行任何操作。 //参数:列表key,Redis::AFTER或Redis::BEFORE,基准元素,插入元素 //返回值:插入成功返回插入后列表元素个数,若基准元素不存在返回-1,若key不存在返回0,若key不是列表返回false。 $ret = $redis->lInsert('city', Redis::AFTER, 'changsha', 'nanjing'); //根据第三个参数count的值,移除列表中与参数value相等的元素。 //count > 0 : 从表头开始向表尾搜索,移除与value相等的元素,数量为count。 //count < 0 : 从表尾开始向表头搜索,移除与value相等的元素,数量为count的绝对值。 //count = 0 : 移除表中所有与value相等的值。 //返回实际删除元素个数 $ret = $redis->lrem('city', 'guangzhou', -2); //对一个列表进行修剪,只保留指定区间的元素,其他元素都删除。成功返回true。 $ret = $redis->ltrim('city', 1, 4);
5.Set操作
//将一个元素加入集合,已经存在集合中的元素则忽略。若集合不存在则先创建,若key不是集合类型则返回false,若元素已存在返回0,插入成功返回1。 $ret = $redis->sAdd('myset', 'hello'); //返回集合中所有成员。 $ret = $redis->sMembers('myset'); //判断指定元素是否是指定集合的成员,是返回true,否则返回false。 $ret = $redis->sismember('myset', 'hello'); //返回集合中元素的数量。 $ret = $redis->scard('myset'); //移除并返回集合中的一个随机元素。 $ret = $redis->sPop('myset'); //返回集合中的一个或多个随机成员元素,返回元素的数量和情况由函数的第二个参数count决定: //如果count为正数,且小于集合基数,那么命令返回一个包含count个元素的数组,数组中的元素各不相同。 //如果count大于等于集合基数,那么返回整个集合。 //如果count为负数,那么命令返回一个数组,数组中的元素可能会重复出现多次,而数组的长度为count的绝对值。 $ret = $redis->sRandMember('myset', 2); //移除集合中指定的一个元素,忽略不存在的元素。删除成功返回1,否则返回0。 $ret = $redis->srem('myset', 'hello'); //迭代集合中的元素。 //参数:key,迭代器变量,匹配模式,每次返回元素数量(默认为10个) $ret = $redis->sscan('myset', $it, 'a*', 5); //将指定成员从一个源集合移动到一个目的集合。若源集合不存在或不包含指定元素则不做任何操作,返回false。 //参数:源集合,目标集合,移动元素 $ret = $redis->sMove('myset', 'myset2', 'aaa'); //返回所有给定集合之间的差集,不存在的集合视为空集。 $ret = $redis->sDiff('myset', 'myset2', 'myset3'); //将所有给定集合之间的差集存储在指定的目的集合中。若目的集合已存在则覆盖它。返回差集元素个数。 //参数:第一个参数为目标集合,存储差集。 $ret = $redis->sDiffStore('myset3', 'myset', 'myset2'); //返回所有给定集合的交集,不存在的集合视为空集。 $ret = $redis->sInter('myset', 'myset2', 'myset3'); //将所有给定集合的交集存储在指定的目的集合中。若目的集合已存在则覆盖它。返回交集元素个数。 //参数:第一个参数为目标集合,存储交集。 $ret = $redis->sInterStore('myset4', 'myset', 'myset2', 'myset3'); //返回所有给定集合的并集,不存在的集合视为空集。 $ret = $redis->sUnion('myset', 'myset2', 'myset3'); //将所有给定集合的并集存储在指定的目的集合中。若目的集合已存在则覆盖它。返回并集元素个数。 //参数:第一个参数为目标集合,存储并集。 $ret = $redis->sUnionStore('myset4', 'myset', 'myset2', 'myset3');
6.Zset操作
//将一个或多个成员元素及其分数值加入到有序集当中。如果某个成员已经是有序集的成员,则更新这个成员的分数值,并通过重新插入这个成员元素,来保证该成员在正确的位置上。分数值可以是整数值或双精度浮点数。 $ret = $redis->zAdd('scores', 98, 'English', 90, 'physics'); //返回有序集中指定区间内的成员。成员按分数值递增排序,分数值相同的则按字典序来排序。 //参数:第四个参数表示是否返回各个元素的分数值,默认为false。 $ret = $redis->zRange('scores', 0, -1, true);//查看Zset所有成员以及它们各自的分数值 //返回有序集中指定区间内的成员。成员按分数值递减排序,分数值相同的则按字典序的逆序来排序。 $ret = $redis->zReverseRange('scores', 0, -1, true); //返回有序集中指定分数区间的成员列表,按分数值递增排序,分数值相同的则按字典序来排序。默认使用闭区间。 $ret = $redis->zRangeByScore('scores', 90, 100, ['withscores'=>true]); //返回有序集中指定分数区间的成员列表,按分数值递减排序,分数值相同的则按字典序的逆序来排序。注意,区间表示的时候大值在前,小值在后,默认使用闭区间。 $ret = $redis->zRevRangeByScore('scores', 100, 90, ['withscores'=>true]); //迭代有序集合中的元素。 //返回值:[元素名=>分数值,,..] $ret = $redis->zscan('scores', $it, '', 10); //返回指定有序集的元素数量。 $ret = $redis->zCard('scores'); //返回有序集中指定分数区间的成员数量。 $ret = $redis->zCount('scores', 90, 100); //返回有序集中指定成员的分数值。若成员不存在则返回false。 $ret = $redis->zScore('scores', 'math'); //返回有序集中指定成员的排名,按分数值递增排序。分数值最小者排名为0。 $ret = $redis->zRank('scores', 'chemistry'); //返回有序集中指定成员的排名,按分数值递减排序。分数值最大者排名为0。 $ret = $redis->zRevRank('scores', 'chemistry'); //移除有序集中的一个或多个成员,忽略不存在的成员。返回删除的元素个数。 $ret = $redis->zRem('scores', 'chemistry', 'English'); //移除有序集中指定排名区间的所有成员。 $ret = $redis->zRemRangeByRank('scores', 0, 2); //移除有序集中指定分数值区间的所有成员。 $ret = $redis->zRemRangeByScore('scores', 80, 90); //对有序集中指定成员的分数值增加指定增量值。若为负数则做减法,若有序集不存在则先创建,若有序集中没有对应成员则先添加,最后再操作。 $ret = $redis->zIncrBy('scores', 2, 'Chinese'); //计算给定一个或多个有序集的交集,并将其存储到一个目的有序集中。结果集中某个成员的分数值是所有给定集下该成员分数值之和。 $ret = $redis->zinterstore('zset3', 'zset2', 'zset1'); //计算给定一个或多个有序集的并集,并将其存储到一个目的有序集中。结果集中某个成员的分数值是所有给定集下该成员分数值之和。 $ret = $redis->zunionstore('zset3', 'zset2', 'zset1');
7.排序操作
//sort 排序 $redis->rpush(‘tab’,3); $redis->rpush(‘tab’,2); $redis->rpush(‘tab’,17); $redis->sort(‘tab’); //返回array(2,3,17) //使用参数,可组合使用 array(‘sort’ => ‘desc’,'limit’ => array(1, 2)) $redis->sort(‘tab’,array(‘sort’ => ‘desc’)); //降序排列,返回array(17,3,2) $redis->sort(‘tab’,array(‘limit’ => array(1, 2))); //返回顺序位置中1的元素2个(这里的2是指个数,而不是位置),返回array(3,17) $redis->sort(‘tab’,array(‘limit’ => array(‘alpha’ => true))); //按首字符排序返回array(17,2,3),因为17的首字符是’1′所以排首位置 $redis->sort(‘tab’,array(‘limit’ => array(‘store’ => ‘ordered’))); //表示永久性排序,返回元素个数 $redis->sort(‘tab’,array(‘limit’ => array(‘get’ => ‘pre_*’))); //使用了通配符’*'过滤元素,表示只返回以’pre_’开头的元素
8.Redis管理操作
//select 指定要操作的数据库 $redis->select(‘mydb’); //指定为mydb,不存在则创建 //flushdb 清空当前库 $redis->flushdb(); //move 移动当库的元素到其它库 $redis->set(‘foo’, ‘bar’); $redis->move(‘foo’, ‘mydb2′); //若’mydb2′库存在 //info 显示服务当状态信息 $redis->info(); //slaveof 配置从服务器 $redis->slaveof(’127.0.0.1′,80); //配置127.0.0.1端口80的服务器为从服务器 $redis->slaveof(); //清除从服务器 //同步保存服务器数据到磁盘 $redis->save(); //异步保存服务器数据到磁盘 $redis->bgsave(); //异步执行一个 AOF(AppendOnly File) 文件重写操作 $redis->bgrewriteaof(); //返回最后更新磁盘的时间 $redis->lastsave(); //set/get多个key-value $mkv = array( ‘usr:0001′ => ‘First user’, ‘usr:0002′ => ‘Second user’, ‘usr:0003′ => ‘Third user’ ); $redis->mset($mkv); //存储多个key对应的value $retval = $redis->mget(array_keys($mkv)); //获取多个key对应的value print_r($retval); //批量操作 $replies = $redis->pipeline(function($pipe) { $pipe->ping(); $pipe->flushdb(); $pipe->incrby(‘counter’, 10); //增量操作 $pipe->incrby(‘counter’, 30); $pipe->exists(‘counter’); $pipe->get(‘counter’); $pipe->mget(‘does_not_exist’, ‘counter’); }); print_r($replies); //CAS,事务性操作 function zpop($client, $zsetKey) { $element = null; $options = array( ‘cas’ => true, // Initialize with support for CAS operations ‘watch’ => $zsetKey, // Key that needs to be WATCHed to detect changes ‘retry’ => 3, // Number of retries on aborted transactions, after // which the client bails out with an exception. ); $txReply = $client->multiExec($options, function($tx) use ($zsetKey, &$element) { @list($element) = $tx->zrange($zsetKey, 0, 0); if (isset($element)) { $tx->multi(); // With CAS, MULTI *must* be explicitly invoked. $tx->zrem($zsetKey, $element); } }); return $element; } $zpopped = zpop($redis, ‘zset’); echo isset($zpopped) ? “ZPOPed $zpopped” : “Nothing to ZPOP!”, “\n”; //对存取的key加前缀,如: ‘nrk:’ $redis->getProfile()->setPreprocessor(new KeyPrefixPreprocessor(‘nrk:’)); //分布式存储的一些方法 $multiple_servers = array( array( ‘host’ => ’127.0.0.1′, ‘port’ => 6379, ‘database’ => 15, ‘alias’ => ‘first’, ), array( ‘host’ => ’127.0.0.1′, ‘port’ => 6380, ‘database’ => 15, ‘alias’ => ‘second’, ), ); use Predis\Distribution\IDistributionStrategy; class NaiveDistributionStrategy implements IDistributionStrategy { private $_nodes, $_nodesCount; public function __constructor() { $this->_nodes = array(); $this->_nodesCount = 0; } public function add($node, $weight = null) { $this->_nodes[] = $node; $this->_nodesCount++; } public function remove($node) { $this->_nodes = array_filter($this->_nodes, function($n) use($node) { return $n !== $node; }); $this->_nodesCount = count($this->_nodes); } public function get($key) { $count = $this->_nodesCount; if ($count === 0) { throw new RuntimeException(‘No connections’); } return $this->_nodes[$count > 1 ? abs(crc32($key) % $count) : 0]; } public function generateKey($value) { return crc32($value); } } //配置键分布策略 $options = array( ‘key_distribution’ => new NaiveDistributionStrategy(), ); $redis = new Predis\Client($multiple_servers, $options); for ($i = 0; $i set(“key:$i”, str_pad($i, 4, ’0′, 0)); $redis->get(“key:$i”); } $server1 = $redis->getClientFor(‘first’)->info(); $server2 = $redis->getClientFor(‘second’)->info(); printf(“Server ‘%s’ has %d keys while server ‘%s’ has %d keys.\n”, ‘first’, $server1['db15']['keys'], ‘second’, $server2['db15']['keys']
参考网址:
PHPRedis手册:http://www.php.cn/php-notebook-93816.html
PHP-redis中文文档:http://www.cnblogs.com/weafer/archive/2011/09/21/2184059.html
https://blog.csdn.net/helencoder/article/details/51275759
转载请注明: ITTXX.CN--分享互联网 » PHP-Redis中文手册和基本实例总结
最后更新:2019-03-25 17:10:22