Redis实现延时队列缓兵之计应用.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

应用2:缓兵之计——延时队列

我们平时习惯于使用Rabbitmq和Kafka作为消息队列中间件,来

给应用程序之间增加异步消息传递功能。这两个中间件都是专业的消

息队列中间件,特性之多超出了大多数人的理解能力。

使用过Rabbitmq的同学知道它使用起来有多复杂,发消息之前要

创建E,再创建Queue,还要将Queue和E通

过某种规则绑定起来,发消息的时候要指定routing-key,还要控

制头部信息。消费者在消费消息之前也要进⾏上⾯⼀系列的繁琐过

程。但是绝大多数情况下,虽然我们的消息队列只有⼀组消费者,但

还是需要经历上⾯这些繁琐的过程。

有了Redis,它就可以让我们出来,对于那些只有⼀组消费者的

消息队列,使用Redis就可以⾮常轻松的搞定。Redis的消息队列

不是专业的消息队列,它没有⾮常多的高级特性,没有ack保证,

如果对消息的可靠性有着极致的追求,那么它就不适合使用。

异步消息队列

Redis的list(列表)数据结构常用来作为异步消息队列使用,使

用rpush/lpush操作⼊队列,使用lpop和rpop来出队列。

应用2:缓兵之计————延时队列

我们平时习惯于使用兔子和kafka作为消息队列中间件,来来给应用程序

之间增加异步消息传递功能。这两个中间件都是专业的消,特性之多超

出了大多数人的理解能力。,特性之多超出了大多数人的理解能力。

使用过兔子的同学知道它使用起来有多复杂,发消息之前要发消息

之前要发消息之前要发消息之前要发消息之前要

有了redis,它就可以让我们出来,对于那些只有一组消费者的,使用redis就可

以非常轻松的搞定。里德斯就可以非常轻松的搞定。,它没有非常多的高级特性,它

没有非常多的高级特性,没有ack保证,如果对消息的可靠性有着极致的追求,那么

它就不适合使用。,那么它就不适合使用。,那么它就不适合使用。

异步消息队列

redis的列表(列表)数据结构常用来作为异步消息队列使用,

使使rpush/lpush操作入队列,使用lpop和rpop来出队列。

rpushnotify-queueapplebananapear

(integer)3

llennotify-queue

(integer)3

lpopnotify-queue

apple

llennotify-queue

(integer)2

lpopnotify-queue

banana

llennotify-queue

(integer)1

lpopnotify-queue

pear

llennotify-queue

(integer)0

lpopnotify-queue

(nil)

上⾯是rpush和lpop结合使用的例子。还可以使用lpush和

rpop结合使用,效果是⼀样的。这⾥不再赘述。

队列空了?

客户端是通过队列的pop操作来获取消息,然后进⾏处理。处理完

了再接着获取消息,再进⾏处理。如此循环往复,这便是作为队列消

费者的客户端的生命周期。

可是如果队列空了,客户端就会陷⼊pop的死循环,不停地pop,

没有数据,接着再pop,又没有数据。这就是浪费生命的空轮询。

空轮询不但拉高了客户端的CPU,redis的QPS也会被拉高,如果

这样空轮询的客户端有几十来个,Redis的慢查询可能会显著增多。

rpush

文档评论(0)

lzjbook118 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档