一口气说出 Redis 16个常见使用场景

01、缓存

作为 Key-Value 形态的内存数据库,Redis 最先会被想到的应用场景便是作为数据缓存。而使用 Redis 缓存数据非常简单,只需要通过 string 类型将序列化后的对象存起来即可,不过也有一些需要注意的地方:

· 必须保证不同对象的 key 不会重复,并且使 key 尽量短,一般使用类名(表名)加主键拼接而成。

· 选择一个优秀的序列化方式也很重要,目的是提高序列化的效率和减少内存占用。

· 缓存内容与数据库的一致性,这里一般有两种做法:

1.只在数据库查询后将对象放入缓存,如果对象发生了修改或删除操作,直接清除对应缓存(或设为过期);

2.在数据库新增和查询后将对象放入缓存,修改后更新缓存,删除后清除对应缓存(或设为过期)。

如果你想学习接口自动化测试,我这边给你推荐一套视频,这个视频可以说是B站播放全网第一的接口自动化测试教程,同时在线人数到达1000人,并且还有笔记可以领取及各路大神技术交流:798478386     

【已更新】B站讲的最详细的Python接口自动化测试实战教程全集(实战最新版)_哔哩哔哩_bilibili【已更新】B站讲的最详细的Python接口自动化测试实战教程全集(实战最新版)共计200条视频,包括:1.【接口自动化】目前软件测试的市场行情以及测试人员能力标准。、2.【接口自动化】全面熟练Requests库以及底层方法调用逻辑、3.【接口自动化】接口自动化实战及正则和JsonPath提取器的应用等,UP主更多精彩视频,请关注UP账号。https://www.bilibili.com/video/BV17p4y1B77x/?spm_id_from=333.337&vd_source=488d25e59e6c5b111f7a1a1a16ecbe9a

02、数据共享分布式

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

例如:分布式Session

图片

03、分布式锁

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

一口气说出 Redis 16个常见使用场景_第1张图片

04、全局ID

int类型,incrby,利用原子性

incrby userid 1000

分库分表的场景,一次性拿一段

05、计数器

int类型,incr方法

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

06、限流

int类型,incr方法

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

07、位统计

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

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

一口气说出 Redis 16个常见使用场景_第2张图片

例如:在线用户统计,留存用户统计

图片

支持按位与、按位或等等操作

图片

计算出7天都在线的用户

图片

08、购物车

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

一口气说出 Redis 16个常见使用场景_第3张图片

· key:用户id;field:商品id;value:商品数量。

· +1:hincr。-1:hdecr。删除:hdel。全选:hgetall。商品数:hlen。

09、用户消息时间线timeline

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

10、消息队列

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

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

· brpop:brpop key1 timeout

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

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

· 队列:先进先除:rpush blpop,左头右尾,右边进入队列,左边出队列

· 栈:先进后出:rpush brpop

11、抽奖

自带一个随机获得值

图片

12、点赞、签到、打卡

一口气说出 Redis 16个常见使用场景_第4张图片

假如上面的微博ID是t1001,用户ID是u3001

用 like:t1001 来维护 t1001 这条微博的所有点赞用户

点赞了这条微博:sadd like:t1001 u3001

取消点赞:srem like:t1001 u3001

是否点赞:sismember like:t1001 u3001

点赞的所有用户:smembers like:t1001

点赞数:scard like:t1001

是不是比数据库简单多了。

13、商品标签

一口气说出 Redis 16个常见使用场景_第5张图片

老规矩,用 tags:i5001 来维护商品所有的标签。

· sadd tags:i5001 画面清晰细腻

· sadd tags:i5001 真彩清晰显示屏

· sadd tags:i5001 流畅至极

14、商品筛选

一口气说出 Redis 16个常见使用场景_第6张图片

一口气说出 Redis 16个常见使用场景_第7张图片

例如:iPhone11 上市了

一口气说出 Redis 16个常见使用场景_第8张图片

筛选商品,苹果的、ios的、屏幕在6.0-6.24之间的,屏幕材质是LCD屏幕

图片

15、用户关注、推荐模型

follow 关注 fans 粉丝

相互关注:

· sadd 1:follow 2

· sadd 2:fans 1

· sadd 1:fans 2

· sadd 2:follow 1

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

· sinter 1:follow 2:fans

可能认识的人:

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

· 用户2可能认识的人:sdiff 1:follow 2:follow

16、排行榜

id 为6001 的新闻点击数加1:

图片

获取今天点击最多的15条:

图片

你可能感兴趣的:(redis,数据库,缓存,jenkins,自动化,windows,面试)