1.用做缓存

String类型

例如:热点数据缓存(例如报表、明星出轨),对象缓存、全页缓存、可以提升热点数据的访问数据

2.session共享存储

String 类型,因为 Redis 是分布式的独立服务,可以在多个应用之间共享

例如:分布式Session

3.分布式锁

String 类型setnx方法,只有不存在时才能添加成功,返回true

4.防重

String 类型setnx方法,只有不存在时才能添加成功,这个特性也可以用来做防重

5.全局ID

int类型,incrby,利用原子性

6.计数器

int类型,incr方法

例如:文章的阅读量、微博点赞数、允许一定的延迟,先写入Redis再定时同步到数据库

7.限流

int类型,incr方法

以访问者的ip和其他信息作为key,访问一次增加一次计数,超过次数则返回false

8.位图统计(bitmap)

String类型的bitcount(1.6.6的bitmap数据结构介绍)

字符是以8位二进制存储的

redis7 特性_redis

9.购物车

String 或hash。所有String可以做的hash都可以做

redis7 特性_redis功能_02

 10.用户消息时间线timeline

list,双向链表,直接作为timeline就好了。插入有序

11.消息队列

List提供了两个阻塞的弹出操作:blpop/brpop,可以设置超时时间

  • blpop:blpop key1 timeout 移除并获取列表的第一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
  • brpop:brpop key1 timeout 移除并获取列表的最后一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

上面的操作。其实就是java的阻塞队列。学习的东西越多。学习成本越低

  • 队列:先进先除:rpush blpop,左头右尾,右边进入队列,左边出队列
  • 栈:先进后出:rpush brpop

12.抽奖

自带一个随机获得值

spop myset

13点赞,签到,打卡

redis7 特性_redis7 特性_03

 14.商品标签

redis7 特性_redis7 特性_04

15.商品筛选

redis7 特性_redis7 特性_05

 16.用户关注,推荐模型

follow 关注 fans 粉丝

相互关注:

sadd 1:follow 2
sadd 2:fans 1
sadd 1:fans 2
sadd 2:follow 1

我关注的人也关注了他(取交集):

sinter 1:follow 2:fans

可能认识的人:

用户1可能认识的人(差集):sdiff 2:follow 1:follow
用户2可能认识的人:sdiff 1:follow 2:follow

 17.排行榜

id 为6001 的新闻点击数加1:zincrby hotNews:20190926 1 n6001

获取今天点击最多的15条:zrevrange hotNews:20190926 0 15 withscores

 

redis7 特性_redis功能_06