rabbitMQ有延迟插件,可以帮助我们实现消息的延迟发送。但是一定要注意,版本必须和当前rabbitMQ的一致,否则可能会出现识别不到插件的问题。
下载地址:
https://www.rabbitmq.com/community-plugins.html
插件解压到Plugins文件夹后,输入安装插件命令:
rabbitmq-plugins enable rabbitmq_delayed_message_exchange
重启rabbitMQ:
rabbitmq-server restart
至此,插件的安装基本完成(rabbitMQ的安装可以自查教程,记得加环境变量PATH)
创建topic等工作就不再赘述,可以参考文章:【spring cloud】stream集成rabbitMQ,实现Topic订阅发布
创建producer时需要注意,要在header中指明x-delay的值,也就是延迟消息的时间。
@PostMapping("sendDM")
public void sendDelayedMessage(@RequestParam() String body, Integer seconds){
MessageBean msg = new MessageBean();
msg.setPayLoad(body);
log.info("redy to send delayed message");
delayedTopicProducer.output().send(MessageBuilder
.withPayload(msg)
.setHeader("x-delay",1000 * seconds)
.build());
}
延迟消息配置如下:
spring.cloud.stream.bindings.delayed-test-consumer.destination=delayed-test-topic
spring.cloud.stream.bindings.delayed-test-producer.destination=delayed-test-topic
#延迟消息配置
spring.cloud.stream.rabbit.bindings.delayed-test-producer.producer.delayed-exchange=true