Rabbitmq延迟队列插件安装

本文详细介绍了如何在RabbitMQ中使用延时队列解决订单未支付过期取消的问题,包括插件下载、安装步骤、配置及使用方法,并强调了在集群环境下注意事项。

安装部分

为何使用延时队列

最近做微信支付的时候遇到一个问题,就是订单未支付过期取消。一开始为了简化开发速度直接用的scheduleThreadPool实现,但是后面发现如果项目部署集群的话这个定时任务会有问题,收集相关资料后就决定使用Rabbitmq的延迟队列delayed-message-exchange。

下载插件

插件下载地址:https://www.rabbitmq.com/community-plugins.html

上面有对应版本提示,按照你的rabbitmq版本下载即可
1

插件安装

首先把你刚才下载的插件上传至服务器,放到任意目录下(我这边放到/root目录下)
在这里插入图片描述

  • docker容器插件安装
    如果你的rabbitmq是通过容器的方式启动的,首先进入容器

    docker exec -it rabbitmq /bin/bash
    

    然后把插件拷贝进容器:

    docker cp /root/rabbitmq_delayed_message_exchange-3.8.0.ez rabbitmq:plugins
    

    此时在容器内plugins目录下执行ls命令,你会发现拷贝进来的插件:
    在这里插入图片描述
    在此目录下执行命令

    rabbitmq-plugins enable rabbitmq_delayed_message_exchange
    

    使插件生效

  • 正常安装
    直接将插件拷贝进你的rabbitmq的plugins目录下,如果不知道你的rabbitmq安装目录的
    通过whereis rabbitmq查看
    使插件生效的方法同上

打开rabbitmq控制台,点击exchange,如果type里出现x-delayed-message类型,则说明安装成功
在这里插入图片描述

使用部分

定义队列和交换机

在这里插入图片描述
队列其实是一个普通队列,交换机类型是关键,设置为延迟消息类型后,消息将会在指定时间之后投递到队列中。

发送消息

/**
 * @author : coderzyj
 * @version : 1.0
 * @description : 延时任务消息发送
 */
@Component
@Slf4j
public class DelayTaskMessageSender {

    @Autowired
    private RabbitTemplate rabbitTemplate;

    /**
     * 发送消息
     *
     * @param message 消息体
     * @param delay   延迟时间
     */
    public void sendDelayMessage(DelayMessage message, Integer delay) {
        log.info("发送延时任务消息:{},延迟时间:{}", JSON.toJSONString(message), delay);
        rabbitTemplate.convertAndSend(RabbitConstants.Exchange.DELAY_EXCHANGE_NAME, RabbitConstants.routingKey.DELAY_ROUTING_KEY,
                JSON.toJSONString(message), message1 -> {
                    message1.getMessageProperties().setDelay(delay);
                    return message1;
                });
    }
}

delay是延迟时间,这边是以毫秒为单位的,使用时别忘记单位转换。

消费消息

延迟队列的消费和普通消息一样,监听队列即可

@Component
@Slf4j
public class DelayMessageListener {

    @RabbitListener(queues = RabbitConstants.Queue.DELAY_QUEUE_NAME)
    public void handle(String message) {
        log.info("接收到延时消息:message ->{}", message);
    }
}

使用限制和注意事项

延迟队列插件有个很大的坑,就是不支持RAM类型的节点,关于ram和disk类型的区别不做赘述,
如果你的rabbitmq是集群的话,你必须注意有没有这类节点存在,否则将无法安装。关于这一点我吃了很大的亏。

这一点有些文章也有介绍,但是没有写明出处,我看了文档之后找到了文档原文,如下所示:
在这里插入图片描述
这是插件github官网 readme的最后一段话,明确了这一限制,链接:
https://github.com/rabbitmq/rabbitmq-delayed-message-exchange

要在本地安装RabbitMQ延迟队列插件,可按照以下步骤进行: 1. **下载插件**:可以从相关的开源仓库或者官方渠道获取RabbitMQ延迟队列插件文件,通常是`.ez`格式。同时可参考引用中提供的相关代码地址,如https://gitee.com/zhangwu2020/rabbitmq_delay_deadletter_application.git和https://gitee.com/zhangwu2020/rabbitmq_delay_application.git ,克隆至本地后根据README.md提示运行代码以辅助理解和使用插件 [^1]。 2. **安装RabbitMQ**:如果还未安装RabbitMQ,需要先进行安装。若使用Docker安装RabbitMQ,这是安装延迟队列的基础步骤 [^2]。 3. **复制插件RabbitMQ镜像**:使用`docker cp`命令将插件复制到RabbitMQ的镜像中。例如`docker cp 本地文件路径 容器ID/容器NAME:容器内路径`,如`docker cp /etc/rabbitmq/rabbitmq_delayed_message_exchange-3.11.1.ez rabbitmq:/plugins` [^4]。 4. **启用插件**:进入RabbitMQ容器,使用命令启用延迟队列插件。 5. **编写消费者代码**:编写代码以接收延迟队列中的消息,例如基于插件延迟队列的消费者代码示例如下: ```java import org.springframework.amqp.core.Message; import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.stereotype.Service; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.util.Date; @Service public class DelayMQReceiver { private static final Logger log = LoggerFactory.getLogger(DelayMQReceiver.class); @RabbitListener(queues = "delayedqueue") public void receivemsg(Message messages){ String msg = new String(messages.getBody()); log.info("当前时间:{},接收时长信息给延迟队列:{}",new Date().toString(),msg); } } ``` 上述代码展示了一个基于插件延迟队列消息消费者,通过`@RabbitListener`注解监听`delayedqueue`队列 [^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值