1 、通过 RabbitMQ 的 DLX 和 TTL 来实现延迟队列
2 、消息,00:00:00 和 00:30:00 ,到点了都没有转发
3 、奇怪的是我访问 web 界面,get message 后就自动会转发了
1
brader 2023-08-21 18:14:33 +08:00
同个队列的所有消息,延迟时间都是一样的吗?
|
3
dunhanson OP 但我那些 9 点,12 点,15 点,18 点 消息 挺正常的
|
4
linauror 2023-08-21 18:21:17 +08:00
死信队列有个限制是,队列里的延迟时间要一致,否则前面的消息没到过期时间,那么后面的其他消息也不会被处理。
有两个处理方式,一个是根据过期时间分别建立死信队列,另外一个是使用 Delayed Message 插件 |
5
brader 2023-08-21 18:21:27 +08:00
@dunhanson 我应该就是这个问题了,我记得我之前看过 rabbitmq 延迟队列相关的文章,其中提到一个弊端就是,同一个队列前面入队的长延时消息会阻塞住后面短延时的消息,比如:
先进去了一条需要延时 1 小时的消息,再进去一条需要延时半小时的小时,实际上半小时后,后一条消息不会出去,因为队列先进先出的特性,被前面的消息堵住了。 简易解决方案就是把不同延时时间的消息分开来,分到不同队列去 |
6
jworg 2023-08-21 18:21:31 +08:00
前面有消息没处理吧,用不严谨的话来说是阻塞的,必须等上一个消息消费了,过期的消息才会被处理,然后转发
|
7
linauror 2023-08-21 18:23:12 +08:00
不过你这个访问一下就转发了,确实挺奇怪的
|
11
silentsky 2023-08-21 19:45:04 +08:00 via Android
延迟队列很多坑 建议别用 rabbitmq
|
12
starck 2023-08-21 23:58:46 +08:00 via iPhone
Rabbitmq 会有队头阻塞问题,可以看看他的插件有没有解决这个问题
|
13
VeryZero 2023-08-22 09:00:50 +08:00
还是用插件做定时吧,用死信队列遇到队头阻塞要出事故的
|