消息中间件(三) 之 RabbitMQ延迟队列

延迟任务

什么是延迟任务

需要延迟一段时间才需要处理的任务. 比如订单关闭, 电商平台一般会给用户30分钟左右交钱时间, 当超时未交钱就需要关闭订单. 订单的延时关闭就是一种延迟任务.

怎么实现延迟任务

定时任务

最普遍的做法应该就是定时任务了, 比如订单关闭例子, 我们会将订单存储在表中, 通过定时任务定时扫表, 比如10分钟一次, 对扫描结果进行时间处理, 如果是超时订单则执行关闭操作.
定时任务实现简单, 缺点是时间延迟时间不准确, 在订单例子中, 如果第一次扫描发现订单为29分钟未支付, 那么该订单只能在第二次扫描时执行关闭, 此时订单已经是39分钟未支付了.
为了提供时间准确性, 我们可以减少定时任务时间, 比如一分钟一次. 时间越短准确性越高, 但是资源消耗的也越多.

RabbitMQ延迟队列

RabbitMQ本身没有延迟队列的概念, 但是它在处理死信时使用了类似的功能. 当队列中出现死信, 我们可以让它路由到指定的队列中, 然后再消费该队列消息, 达到延迟功能.
那么什么是死信 dead-lettered message?
官网解释在以下三种情况下message可以成为dead-lettered message
1 The message is negatively acknowledged by a consumer using basic.reject or basic.nack with requeue parameter set to false.
2 The message expires due to per-message TTL; or
3 The message is dropped because its queue exceeded a length limit

准确译文
1 被女神(消费者)拒绝的, 并且没有女朋友(requeue = false)就不让回家(重入队列)的你
2 岁数太大(达到ttl time to live)被公司辞退的你
3 站在车门口, 怎么也挤不上公交车(队列已满)的你
满足任意一个条件的话那你就可以称为~死信了

擦干眼泪我们继续看你的归处~
如果队列在声明的时候设置了dlx(dead letter exchange 就是一个Exchange), 当你满足条件的时候, queue会自动将你路由到该队列, 如果好巧不巧的这时候dlx还没有声明, 或者queue在声明的时候没有设置dlx, 那么你会像屁一样消失在这个世界, 还不能是响屁, 官网说的if it is missing then, the messages will be silently dropped.

合上下巴, 回头想想如何自救
对于第一种情况, 只能告诉你, 认清自己, 和父母搞好关系(.)
对于第三种情况, 早起5分钟能死么?
重点是第二种, 超时正好对应我们的延迟功能. 时间一天天过, 虽然你面相18, 实际已经过了三次本命年. 时间面前任何人任何事都是渣渣, 你能做的就是努力提升自己, 让你的实力 >= 年龄, 一直进步, ttl过期就是你走到更高level(英语已过CET-20)的时候.
努力要有目标, 在进入公司时就要有. 开始创建你的职业生涯~
声明职业生涯

image

名词解释

x-message-ttl 队列中消息存活时间, 单位ms, 超时则认为是死信
x-dead-letter-exchange 出现死信时路由到该参数指定的Exchange(dlx)
x-dead-letter-routing-key dlx路由到其他队列使用的routingKey

x-message-ttl属性就是我们可以利用的延迟时间, 设置好上面三个属性, 然后最后消费死信最终路由到的队列, 就完成了一个延迟任务的功能.
创建e.opportunity并通过r.raise绑定q.senior.engineer
延迟队列相关的设置好了, 还缺一个入口, 声明e.send, 用来发送消息到q.intermediate.engineer .
在控制台发送消息


image

成为一个中级工程师


image

30岁了! 恭喜你更进一步~


image

在这里可以看到一些参数, 比如成为死信的原因, 死信从哪个队列来的等.

policy

上面的步骤基本就可以实现RabbitMQ的延迟队列功能, 但是有个小问题, 如果我们想改变延迟时间怎么办? 在RabbitMQ中, 一旦声明了队列或者Exchange, 那么设置的属性是无法修改的, 像上面设置的ttl我们是没有办法在运行时修改的, 这种情况下, 我们只好重新创建一个队列, 设置指定的ttl. 那么有没有可以运行时修改延迟时间的办法呢? 有的~
RabbitMQ中运行时修改的参数叫做parameter, parameter不仅可以运行时修改, 还可以给集群中多个节点设置统一属性. 而policy就是某些特殊parameter, 其中就包括我们上线提到的ttl, dlx等.

设置policy很简单


image

这里的演示就有你来完成吧~ 需要注意的是运行时修改的message-ttl对于已经入队列的消息是无效, 这个也很合理, 否则也无法计算失效时间. dead-letter-exchange运行时修改对于入队列的消息是有效的. 猜想下这里的逻辑, 消息入队列, 根据队列message-ttl设置消息ttl, 当消息超时, 根据此时队列的dead-letter-exchange进行路由.

RocketMQ

内置18种消息延迟队列, 看起来理念和RabbitMQ差不多, 这个后面补一篇文章学习下

redis

设置key失效时间, 失效通知. 同上

kafka

时间轮~同上

总结

学习了RabbitMQ如何实现延迟任务, 并提供了其他几种实现(虽然作者还没有看...). 后面继续补充其他实现(really?)

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351