目的:
rabbitmq实现延时队列
步骤:
1.docker 下为rabbitmq安装rabbitmq-delayed-message-exchange插件
2.使用bean注入支持延时队列类型的交换机
3.使用注解注入延时队列
4.延迟发送mq
1.docker 下为rabbitmq安装rabbitmq-delayed-message-exchange插件
第一步:了解自己的rabbitmq的版本,进入rabbitmq后台可见版本号
第二步:上rabbitmq的官网下载对应版本的rabbitmq-delayed-message-exchange插件的ez类型插件安装包
rabbitmq的官网下载插件地址:https://www.rabbitmq.com/community-plugins.html
第三步:上传到linux上,上传完毕到目录下把该文件拷贝到相应docker的rabbitmq容器的/plugins目录里面,使用命令:docker cp 上传目录/xx.ez 容器id(或者容器名):/plugins
例如:
docker cp rabbitmq_delayed_message_exchange-3.9.0.ez rabbitmq:/plugins
然后进入docker容器里面,使用命令:docker exec -it 容器id(或者容器名) /bin/bash
例如:
docker exec -it rabbitmq /bin/bash
进入docker容器后使用安装命令
rabbitmq-plugins enable rabbitmq_delayed_message_exchange
查看插件是否安装
rabbitmq-plugins list
2.使用bean注入支持延时队列类型的交换机
/**
* 注入name为'x-delayed-message'customExchange,默认名字就是空字符串,可以不注入
*/
@Bean
public CustomExchange delayedExchange() {
Map<String, Object> args = new HashMap<>();
args.put("x-delayed-type", "direct");
return new CustomExchange("delayedExchange", "x-delayed-message", true, false, args);
}
效果如下:
3.使用注解注入延时队列
@RabbitListener(
bindings = {
@QueueBinding(
value = @Queue(value = "delayedQueue",durable = "true"),
exchange = @Exchange(value ="delayedExchange",type ="x-delayed-message" ),
key = {"delayedQueue_key"}
)
})
@RabbitHandler
public void delayedQueue(Message message,Channel channel) throws Exception {
return;
}
效果如下:
4.延迟发送mq
@Autowired
private AmqpTemplate amqpTemplate;
/**
* 延迟发送(毫秒)
*
* @param queueKey
* @param object
* @param delay 毫秒
*/
public void sendDelay(String queueKey, Object object, Integer delay) {
try {
amqpTemplate.convertAndSend("delayedExchange", queueKey, object, new MessagePostProcessor() {
@Override
public Message postProcessMessage(Message message) throws AmqpException {
message.getMessageProperties().setDelay(delay);
return message;
}
});
} catch (Exception e) {
logger.error(e);
}
}