redis典型使用场景

news/2024/7/23 18:39:09

1.缓存功能
下图是比较典型的缓存使用场景,其中Redis作为缓存层,MySQL作为缓存层,绝大部分请求的数据都是从Redis中获取,由于Redis具有支撑高并发的特性,所以缓存通常起到加速读写和降低后端压力的作用。

Redis+MySQL 组成的缓存存储架构图

2. 计数
许多应用都会使用Redis作为计数的基础工具,它可以实现快速计数、查询缓存的功能,同时数据可以异步落地到其他数据源。例如某些视频播放数系统就是使用Redis作为视频播放数计数的基础组件,用户每播放一次视频,响应的视屏播放数就会自增1。

3. 共享session
一个分布式Web服务将用户的Session信息(例如用户登录信息)保存在各自服务器中,这样会造成一个问题,出于负载均衡的考虑,分布式服务会将用户的访问均衡到不同服务器上,用户刷新一次访问可能会发现需要重新登录,这个问题是用户无法容忍的。
为了解决这个问题,可以使用Redis将用户的Session进行几种管理,在这种模式下只要保证Redis是高可用和扩展性的,每次用户更新或者查询登录信息都直接从Redis中集中获取。

4. 限速
很多应用出于安全的考虑,会在每次进行登录时,让用户输入手机验证码,从而确定是否是用户本人。但是为了短信接口不被频繁访问,会限制用户每分钟获取验证码的频率,例如一分钟不超过5次。

5. 消息队列
Redis的lpush+brpop命令组合即可实现阻塞队列,生产者客户端使用lrpush从列表左侧插入元素,多个消费者客户端使用brpop命令阻塞式的“抢”列表尾部的元素,多个客户端保证了消费者的负载均衡和高可用性。

6. 文章列表
每个用户有属于自己的文章列表,现需要分页展示文章列表。此时可以考虑使用列表,因为列表不但是有序的,同时支持按照索引范围获取元素。
使用列表类型保存和获取文章列表会存在两个问题。第一如果每次分页获取的文章个数较多,需要执行多次hgetall操作,此时可以考虑使用Pipeline批量获取,或者考虑将文章数据序列化为字符串类型,使用mget批量获取。第二分页获取文章列表时,lrange命令在列表两端性能较好,但是如果列表较大,获取列表中间范围的元素性能会变差,此时可以考虑将列表做二级拆分,或者使用Redis3.2的quicklist内部编码实现,它结合ziplist和linkedlist的特点,获取列表中间范围的元素时也可以高效访问。

7. 标签
集合类型比较典型的使用场景是标签(tag)。例如一个用户可能对娱乐、体育比较感兴趣,另一个用户可能对历史、新闻比较感兴趣。这些兴趣点就是标签。有了这些数据就可以得到喜欢同一个标签的人,以及用户的共同喜好的标签,这些数据对于用户体验以及增强用户黏度比较重要。例如一个电子商务的网站会对不同标签的用户做不同类型的推荐,比如对数码产品比较感兴趣的人,在各个页面或者通过邮件的形式给他们推荐最新的数码产品,通常会为网站带来更多的利益。

8. 排行榜
有序集合比较典型的使用场景就是排行榜系统。例如视频网站需要对用户上传的视频做排行榜,榜单的维度可能是多个方面的:按照时间、按照播放数量、按照获得的赞数。本节使用赞数这个维度,记录每天用户上传视频的排行榜。

摘自-Redis开发与运维


http://www.niftyadmin.cn/n/4556954.html

相关文章

Word Amalgamation

链接 [https://vjudge.net/contest/212939#problem/C] 题意 给你个字典,字典包含若干个单词; 再给你若干个单词,让你输出跟这个单词有相同的字母的字典里的单词(不考虑顺序) 分析 STL set的应用以及next_permutation的应用 用set保存字典里的…

要考3级C了 谢谢哈~ 拜托了 请问谁有VC++6.0的英文版下载地址

searchVC%2B%2B&suffix&restype-1&id2 您去看下 这里很多资源 里面有英文版的 VC6.0(英文版)下载: ftp://fzskydown:down61.152.92.98//VC60EN.iso (复制到迅雷中下载) VC6.0 SP6(英文版)下载 http://download.microsoft.com/download/1/9/f/19fe4660-5792-4683-99…

摘录的关于代码维护性的文章片段

https://blog.csdn.net/zhanghuiqi205/article/details/80332729 检查代码可读性和可维护性: 如果代码的可读性强,那么维护起来也就方便很多;一个好的代码规范和编码风格会节省大家对代码的理解时间,减少维护成本;虽然…

Redis的五种数据类型详解

type命令实际返回的就是当前键的数据结构类型,他们分别是:String、hash、list、set(集合)、zset(有序集合),但这些只是Redis对外的数据结构。 实际上每一种数据结构都有自己底层的内部编码实现,…

B/S 与 C/S 相比各有何优缺点

相对于C/S结构 MYIE等)运行软件 如Internet Explorer 而客户端采用浏览器(Browse 就是只安装维护一个服务器(Server) B/S结构软件的好处 何谓B/S结构 1.首先 但与B/S相比 有了很大的进步 尽管C/S结构相对于更早的文件服务器来说 即…

Kafka 概念,安装,常用命令(一)

1、什么是Kafka Kafka可以看成一个流平台,这个平台上可以发布和订阅数据流,并把他们保存起来,进行处理。Kafka有点像消息系统,允许发布和订阅消息流,但是它和传统的消息系统有很大的差异,首先,…

Excel的用到的常规的技巧

这几天在做各种发票的报表,好几百的数据当然离不开EXCel,自己又是个白班,就记录下啦! EXCEL 判断某一单元格值是否包含在某一列中 就在Excel的表格中加入这个函数:IF(ISERROR(VLOOKUP(D2,A2:A87,1,0)),"N",&…

要漂亮免费好用的 300分求.Net下WinForm换肤控件

iegb2312&bsMFC%D6%D0%B9%D8%D3%DA%B1%A3%B4%E6%CA%FD%BE%DD%B5%BDExcel&sr&z&cl3&f8&wd.Net%CF%C2WinForm%BB%BB%B7%F4%BF%D8%BC%FE&ct0http://hi.baidu.com/dujinghong/blog/item/74d48e5c3abfeb46faf2c0ef.html这两个不错 我上个月还在开发KTV了…