今天遇到一个同事,说想用rabbitmq来做定时任务,我想着这很简单啊,就是利用它的延迟消息来做就是了啊。但是,问题是他也是这样做的,但是并没有延迟执行代码,而是立刻执行了。怎么回事?
问题
利用rabbitmq的延迟消息执行定时任务,没有定时执行。现在就来测试这个问题。
我们写个测试方法来测试发送消息,并且延迟执行。
@GetMapping("/sendMessage")
public String messageWithMQ(@RequestParam String message, @RequestParam Long delay) {
log.info("Send: " message);
testTopic.output().send(MessageBuilder.withPayload(message).setHeader("delay", delay).build());
return "ok";
}
这样我们来请求,delay为6000毫秒,接口6秒后确实执行了代码。
现在我们设置延迟时间为一年。现在继续请求接口,但是发现消息被立即消费了。看来问题原因就是,延迟时间超过极限值了。
原因
这里的失败主要与消息的过期时间(TTL)有直接的关系。在RabbitMQ中,消息的过期时间必须是非负 32 位整数,即:0 <= n <= 2^32