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