1、string 的过时时间在从新设置值以后会被清除
复制代码
127.0.0.1:6379> set hello 3
OK
127.0.0.1:6379> get hello
"3"
127.0.0.1:6379> ttl hello
(integer) -1
127.0.0.1:6379> expire hello 3000
(integer) 1
127.0.0.1:6379> set hello 4
OK
127.0.0.1:6379> ttl hello
(integer) -1
复制代码
2、设置 string 类型的值能够覆盖任何其余类型
复制代码
127.0.0.1:6379> sadd settest 1,2
(integer) 1
127.0.0.1:6379> type settest
set
127.0.0.1:6379> set settest hello
OK
127.0.0.1:6379> type settest
string
127.0.0.1:6379> sadd settest a,b
(error) WRONGTYPE Operation against a key holding the wrong kind of value
复制代码
Redis lists 基于 Linked Lists 实现。头尾操做极速,检索较慢
复制代码
有序集合的排序默认按照字典序排列
复制代码
无论是简单和复杂的数据均可以直接转为string存储。nginx
key: active:spring2019:title value:"2019春节活动" 操做:setredis
商品信息,省市区信息,活动配置等一系列不常变化的冷数据缓存spring
很是热门数据的缓存,游戏排行,后台每秒更新一次数据sql
2019春节活动参加人数数据库
key: active:spring2019:total value:3045 操做:incrvim
一我的一天只能进行一次签到缓存
key:active:checkin:userId:10000:day:20190101 value:签到时间戳 操做:expirebash
下面的代码不严谨,nx 能够放并发数据结构
127.0.0.1:6379> set lockkey 1 nx
OK
127.0.0.1:6379> set lockkey 1 nx
(nil)
复制代码
list架构
push,pop
push,pop
阻塞式访问 BRPOP 和 BLPOP 命令
set
2019春节活动参加人数
key: active:spring2019:users value:100010,10020 操做:不少
用户标签
商家标签
春节活动一共有 abcde 5个任务,用户A已经完成a,b,用户B已经完成 c,d
用户A,用户B 都完成的任务
用户A,用户B 任一完成的任务
用户A尚未完成的任务
从礼品库 set 中随机得到一个礼品
hash
用户在活动期间一共得到了不一样种类奖品数量
key:active:spring:g'ifts:user:10010 value:{"giftA":2,"giftB":5} 操做:不少
能够直接对 giftA 执行 incr 操做
zset
用户消费排行,点赞排行等
key:active:spring:star:rank value:用户ID,score:点赞数量 操做:不少
根据分数获取 top 10
查询某个用户的分数
查询 得分在90-100 之间的用户
有时候咱们的得分并非由某一项业务值决定的,多是由两项业务值来排序的,好比先看用户的实际得分,在看用户等级,那么咱们在设计score的时候能够用小数点以前的值表示得分,小数点以后的值表示等级,若是有其余特殊要求,还能够考虑得分加上某个极大值来处理。
不要用list存大量数据并检索
复制代码
判断用户有没有参加应该用set,不该该每一个用户一个key
复制代码
群内提供免费的Java架构学习资料,QQ群:643459718
(里面有高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码, MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)