Php+Redis函数使用总结

因项目需求,冷落了redis,今天再重新熟悉一下:

  1 <?php
  2 //连接
  3 $redis = New Redis();
  4 $redis->connect(‘127.0.0.1‘,‘6379‘,1);//短链接,本地host,端口号为6379,超过1秒放弃链接(此参数可不设置)
  5 $redis->open(‘127.0.0.1‘,‘6379‘,1);//同上
  6 $redis->pconnect(‘127.0.0.1‘,‘6379‘,1);//长链接,本地host,端口号为6379,超过1秒放弃链接(此参数可不设置)
  7 $redis->popen(‘127.0.0.1‘,‘6379‘,1);//同上
  8 $redis->auth(‘password‘);//登录验证密码,返回【true|false】
  9 $redis->select(0);// 选择redis库,默认是0.0~15共16个库
 10 $redis->close();//释放资源
 11 $redis->ping();// 检查是否还在链接
 12 $redis->ttl(‘key‘);//查看key的失效时间,返回【-1|timestamps】
 13 $redis->persist(‘key‘);//移除失效时间【1|0】
 14 $redis->sort(‘key‘,[$array]);//返回或保存给定列表、集合、有序集合key中经过排序的元素,$array为参数limit等!【配合$array很强大】 [array|false]
 15 $redis->expire(‘key‘,‘time(s)‘);//设置失效时间【true|false】
 16 $redis->move(‘key‘,‘dbindex‘);//将当前库的key移动到指定库中【1|0】
 17
 18 //string
 19 $redis->strlen(‘key‘);//获取当前key的长度
 20 $redis->append(‘key‘,‘string‘);//把string追加到key现有的value中[追加后的个数]
 21 $redis->incr(‘key‘);//自增1,如不存在key,赋值为1(只对整数有效,存储以10进制64位,redis中为str)[new_num | false]
 22 $redis->incrby(‘key‘,$num);//自增$num,不存在为赋值,值需为整数[new_num | false]
 23 $redis->decr(‘key‘);//自减1,[new_num | false]
 24 $redis->decrby(‘key‘,$num);//自减$num,[ new_num | false]
 25 $redis->setex(‘key‘,10,‘value‘);//key=value,有效期为10秒[true]
 26 //list
 27 $redis->llen(‘key‘);//返回列表key的长度,不存在key返回0, [ len | 0]
 28 //set
 29 $redis->scard(‘key‘);//返回集合key的基数(集合中元素的数量)。[num | 0]
 30 $redis->sMove(‘key1‘, ‘key2‘, ‘member‘);//移动,将member元素从key1集合移动到key2集合。[1 | 0]
 31 //Zset
 32 $redis->zcard(‘key‘);//返回集合key的基数(集合中元素的数量)。[num | 0]
 33 $redis->zcount(‘key‘,0,-1);//返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0]
 34 //hash
 35 $redis->hexists(‘key‘,‘field‘);//查看hash中是否存在field,[1 | 0]
 36 $redis->hincrby(‘key‘,‘field‘,$int_num);//为哈希表key中的域field的值加上量(+|-)num,[new_num | false]
 37 $redis->hlen(‘key‘);//返回哈希表key中域的数量。[ num | 0]
 38
 39
 40
 41 /*3.Server*/
 42 $redis->dbSize();//返回当前库中的key的个数
 43 $redis->flushAll();//清空整个redis[总true]
 44 $redis->flushDB();//清空当前redis库[总true]
 45 $redis->save();//同步??把数据存储到磁盘-dump.rdb[true]
 46 $redis->bgsave();//异步??把数据存储到磁盘-dump.rdb[true]
 47 $redis->info();//查询当前redis的状态 [verson:2.4.5....]
 48 $redis->lastSave();//上次存储时间key的时间[timestamp]
 49
 50 $redis->watch(‘key‘,‘keyn‘);//监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 [true]
 51 $redis->unwatch(‘key‘,‘keyn‘);//取消监视一个(或多个) key [true]
 52 $redis->multi(Redis::MULTI);//开启事务,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。
 53 $redis->multi(Redis::PIPELINE);//开启管道,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。
 54 $redis->exec();//执行所有事务块内的命令,;【事务块内所有命令的返回值,按命令执行的先后顺序排列,当操作被打断时,返回空值 false】
 55
 56
 57
 58 /*4.String,键值对,创建更新同操作*/
 59 $redis->setOption(Redis::OPT_PREFIX,‘hf_‘);//设置表前缀为hf_
 60 $redis->set(‘key‘,1);//设置key=aa value=1 [true]
 61 $redis->mset($arr);//设置一个或多个键值[true]
 62 $redis->setnx(‘key‘,‘value‘);//key=value,key存在返回false[|true]
 63 $redis->get(‘key‘);//获取key [value]
 64 $redis->mget($arr);//(string|arr),返回所查询键的值
 65 $redis->del($key_arr);//(string|arr)删除key,支持数组批量删除【返回删除个数】
 66 $redis->delete($key_str,$key2,$key3);//删除keys,[del_num]
 67 $redis->getset(‘old_key‘,‘new_value‘);//先获得key的值,然后重新赋值,[old_value | false]
 68
 69
 70
 71 /*5.List栈的结构,注意表头表尾,创建更新分开操作*/
 72 $redis->lpush(‘key‘,‘value‘);//增,只能将一个值value插入到列表key的表头,不存在就创建 [列表的长度 |false]
 73 $redis->rpush(‘key‘,‘value‘);//增,只能将一个值value插入到列表key的表尾 [列表的长度 |false]
 74 $redis->lInsert(‘key‘, Redis::AFTER, ‘value‘, ‘new_value‘);//增,将值value插入到列表key当中,位于值value之前或之后。[new_len | false]
 75 $redis->lpushx(‘key‘,‘value‘);//增,只能将一个值value插入到列表key的表头,不存在不创建 [列表的长度 |false]
 76 $redis->rpushx(‘key‘,‘value‘);//增,只能将一个值value插入到列表key的表尾,不存在不创建 [列表的长度 |false]
 77 $redis->lpop(‘key‘);//删,移除并返回列表key的头元素,[被删元素 | false]
 78 $redis->rpop(‘key‘);//删,移除并返回列表key的尾元素,[被删元素 | false]
 79 $redis->lrem(‘key‘,‘value‘,0);//删,根据参数count的值,移除列表中与参数value相等的元素count=(0|-n表头向尾|+n表尾向头移除n个value)  [被移除的数量 | 0]
 80 $redis->ltrim(‘key‘,start,end);//删,列表修剪,保留(start,end)之间的值 [true|false]
 81 $redis->lset(‘key‘,index,‘new_v‘);//改,从表头数,将列表key下标为第index的元素的值为new_v, [true | false]
 82 $redis->lindex(‘key‘,index);//查,返回列表key中,下标为index的元素[value|false]
 83 $redis->lrange(‘key‘,0,-1);//查,(start,stop|0,-1)返回列表key中指定区间内的元素,区间以偏移量start和stop指定。[array|false]
 84
 85 /*6.Set,没有重复的member,创建更新同操作*/
 86 $redis->sadd(‘key‘,‘value1‘,‘value2‘,‘valuen‘);//增,改,将一个或多个member元素加入到集合key当中,已经存在于集合的member元素将被忽略。[insert_num]
 87 $redis->srem(‘key‘,‘value1‘,‘value2‘,‘valuen‘);//删,移除集合key中的一个或多个member元素,不存在的member元素会被忽略 [del_num | false]
 88 $redis->smembers(‘key‘);//查,返回集合key中的所有成员 [array | ‘‘]
 89 $redis->sismember(‘key‘,‘member‘);//判断member元素是否是集合key的成员 [1 | 0]
 90 $redis->spop(‘key‘);//删,移除并返回集合中的一个随机元素 [member | false]
 91 $redis->srandmember(‘key‘);//查,返回集合中的一个随机元素 [member | false]
 92 $redis->sinter(‘key1‘,‘key2‘,‘keyn‘);//查,返回所有给定集合的交集 [array | false]
 93 $redis->sunion(‘key1‘,‘key2‘,‘keyn‘);//查,返回所有给定集合的并集 [array | false]
 94 $redis->sdiff(‘key1‘,‘key2‘,‘keyn‘);//查,返回所有给定集合的差集 [array | false]
 95
 96
 97 /*7.Zset,没有重复的member,有排序顺序,创建更新同操作*/
 98 $redis->zAdd(‘key‘,$score1,$member1,$scoreN,$memberN);//增,改,将一个或多个member元素及其score值加入到有序集key当中。[num | 0]
 99 $redis->zrem(‘key‘,‘member1‘,‘membern‘);//删,移除有序集key中的一个或多个成员,不存在的成员将被忽略。[del_num | 0]
100 $redis->zscore(‘key‘,‘member‘);//查,通过值反拿权 [num | null]
101 $redis->zrange(‘key‘,$start,$stop);//查,通过(score从小到大)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]
102 $redis->zrevrange(‘key‘,$start,$stop);//查,通过(score从大到小)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]
103 $redis->zrangebyscore(‘key‘,$min,$max[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从小到大排)成员[array | null]
104    $redis->zrevrangebyscore(‘key‘,$max,$min[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从大到小排)成员[array | null]
105    $redis->zrank(‘key‘,‘member‘);//查,通过member值查(score从小到大)排名结果中的【member排序名次】[order | null]
106    $redis->zrevrank(‘key‘,‘member‘);//查,通过member值查(score从大到小)排名结果中的【member排序名次】[order | null]
107    $redis->ZINTERSTORE();//交集
108    $redis->ZUNIONSTORE();//差集
109
110 /*8.Hash,表结构,创建更新同操作*/
111    $redis->hset(‘key‘,‘field‘,‘value‘);//增,改,将哈希表key中的域field的值设为value,不存在创建,存在就覆盖【1 | 0】
112    $redis->hget(‘key‘,‘field‘);//查,取值【value|false】
113    $arr = array(‘one‘=>1,2,3);$arr2 = array(‘one‘,0,1);
114    $redis->hmset(‘key‘,$arr);//增,改,设置多值$arr为(索引|关联)数组,$arr[key]=field, [ true ]
115    $redis->hmget(‘key‘,$arr2);//查,获取指定下标的field,[$arr | false]
116    $redis->hgetall(‘key‘);//查,返回哈希表key中的所有域和值。[当key不存在时,返回一个空表]
117    $redis->hkeys(‘key‘);//查,返回哈希表key中的所有域。[当key不存在时,返回一个空表]
118    $redis->hvals(‘key‘);//查,返回哈希表key中的所有值。[当key不存在时,返回一个空表]
119    $redis->hdel(‘key‘,$arr2);//删,删除指定下标的field,不存在的域将被忽略,[num | false]

参考:https://blog.csdn.net/ty_hf/article/details/51165944

<?php//连接$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.0~15共16个库$redis->close();//释放资源$redis->ping();// 检查是否还在链接$redis->ttl(‘key‘);//查看key的失效时间,返回【-1|timestamps】$redis->persist(‘key‘);//移除失效时间【1|0】$redis->sort(‘key‘,[$array]);//返回或保存给定列表、集合、有序集合key中经过排序的元素,$array为参数limit等!【配合$array很强大】 [array|false]$redis->expire(‘key‘,‘time(s)‘);//设置失效时间【true|false】$redis->move(‘key‘,‘dbindex‘);//将当前库的key移动到指定库中【1|0】

//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]

原文地址:https://www.cnblogs.com/yuanwanli/p/8685001.html

时间: 2024-10-21 18:44:11

Php+Redis函数使用总结的相关文章

php+redis实现电商秒杀功能

这一次总结和分享用Redis实现分布式锁来完成电商的秒杀功能.先扯点个人观点,之前我看了一篇博文说博客园的文章大部分都是分享代码,博文里强调说分享思路比分享代码更重要(貌似大概是这个意思,若有误请谅解),但我觉得,分享思路固然重要,但有了思路,却没有实现的代码,那会让人觉得很浮夸的,在工作中的程序猿都知道,你去实现一个功能模块,一段代码,虽然你有了思路,但是实现的过程也是很耗时的,特别是代码调试,还有各种测试等等.所以我认为,思路+代码,才是一篇好博文的主要核心. 直接进入主题. 一.前言 双十

php+redis实现消息队列

原文地址:http://www.cnblogs.com/lisqiong/p/6039460.htmlphp+redis实现消息队列 ? 个人理解在项目中使用消息队列一般是有如下几个原因: 把瞬间服务器的请求处理换成异步处理,缓解服务器的压力 实现数据顺序排列获取 ?redis实现消息队列步骤如下: 1).redis函数rpush,lpop 2).建议定时任务入队列 3)创建定时任务出队列 文件:demo.php插入数据到redis队列 1 2 3 4 5 6 7 8 9 10 11 12 13

Redis源码阅读笔记(1)——简单动态字符串sds实现原理

首先,sds即simple dynamic string,redis实现这个的时候使用了一个技巧,并且C99将其收录为标准,即柔性数组成员(flexible array member),参考资料见这里.柔性数组成员不占用结构体的空间,只作为一个符号地址存在,而且必须是结构体的最后一个成员.柔性数组成员不仅可以用于字符数组,还可以是元素为其它类型的数组.C99中,结构中的最后一个元素允许是未知大小的数组,这就叫做柔性数组成员,但结构中的柔性数组成员前面必须至少一个其他成员.柔性数组成员允许结构中包

&lt;Redis实战&gt;5.4.3 Redis自动连接管理

原文:https://redislabs.com/ebook/redis-in-action/part-2-core-concepts-2/chapter-5-using-redis-for-application-support/5-4-service-discovery-and-configuration/5-4-3-automatic-redis-connection-management 手动创建Redis连接可能比较艰难,不仅仅需要不断的读取配置,如果我们使用上一节的配置管理函数,我们

基于Redis实现分布式锁以及任务队列

一.前言 双十一刚过不久,大家都知道在天猫.京东.苏宁等等电商网站上有很多秒杀活动,例如在某一个时刻抢购一个原价1999现在秒杀价只要999的手机时,会迎来一个用户请求的高峰期,可能会有几十万几百万的并发量,来抢这个手机,在高并发的情形下会对数据库服务器或者是文件服务器应用服务器造成巨大的压力,严重时说不定就宕机了,另一个问题是,秒杀的东西都是有量的,例如一款手机只有10台的量秒杀,那么,在高并发的情况下,成千上万条数据更新数据库(例如10台的量被人抢一台就会在数据集某些记录下 减1),那次这个

用Redis实现分布式锁 与 实现任务队列

这一次总结和分享用Redis实现分布式锁 与 实现任务队列 这两大强大的功能.先扯点个人观点,之前我看了一篇博文说博客园的文章大部分都是分享代码,博文里强调说分享思路比分享代码更重要(貌似大概是这个意思,若有误请谅解),但我觉得,分享思路固然重要,但有了思路,却没有实现的代码,那会让人觉得很浮夸的,在工作中的程序猿都知道,你去实现一个功能模块,一段代码,虽然你有了思路,但是实现的过程也是很耗时的,特别是代码调试,还有各种测试等等.所以我认为,思路+代码,才是一篇好博文的主要核心. 直接进入主题.

OpenResty + Lua + Redis 实现 客户端ip防刷

一.环境说明: 在Centos7上安装openresty此次安装采用的是下载openresty的yum源来安装 [[email protected] conf]# sudo yum-config-manager --add-repo https://openresty.org/yum/cn/centos/OpenResty.repo sudo:yum-config-manager:找不到命令解决办法: [[email protected] conf]# yum -y install yum-ut

高并发架构系列:Redis并发竞争key的解决方案详解

需求由来 1.Redis高并发的问题 Redis缓存的高性能有目共睹,应用的场景也是非常广泛,但是在高并发的场景下,也会出现问题:缓存击穿.缓存雪崩.缓存和数据一致性,以及今天要谈到的缓存并发竞争. 这里的并发指的是多个redis的client同时set key引起的并发问题. 2.出现并发设置Key的原因 Redis是一种单线程机制的nosql数据库,基于key-value,数据可持久化落盘.由于单线程所以Redis本身并没有锁的概念,多个客户端连接并不存在竞争关系,但是利用jedis等客户端

Redis系列-存储篇sorted set主要操作函数小结

redis支持有序集合,即sorted set.sorted set在set的基础上,增加了排序属性,是set的升级版.这里简要谈谈sorted set的常用函数: 1)insert a)  zadd 语法:zadd key score member [[score member] [score member] ...] 解释:增加一个或多个member[根据score排序]到有序集key中,如果member已经存在,只更新score.返回增加member个数,不包含已经存在的member [p