RabbitMQ自学笔记——延迟消息

本文介绍了如何在RabbitMQ中实现延迟消息,包括使用死信交换机处理过期未消费的消息,以及官方提供的支持延迟消息的插件。发送方需设置消息过期时间和使用特定交换机,消费者则需配置接收延迟消息。
摘要由CSDN通过智能技术生成

延迟消息:生产者发送消息时指定一个时间,消费者不会立刻收到消息,而是在指定时间之后才收到消息。

1.死信交换机

        初始设定消息的过期时间为30s,由于simple.queue队列没有消费者,当消息到达过期时间,没人消费就会成为死信,然后投到死信交换机dlx.direct中,就可供消费者消费。通过这种机制就可实现延迟消息。

发送方:

 接收方:

2.延迟消息插件

RabbitMQ的官方也推出了一个插件,原理就是设计了一种支持延迟消息功能的交换机,当消息投递到交换机后可以暂存一定的时间,到期后再投入到队列中。虽然使用很便捷,但是对mq的性能来说还是有影响。

发送方发送消息时需要通过消息头来设置过期时间:

  消费者方设置交换机支持延迟消息:

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
RabbitMQ可以通过安装延迟消息插件来实现延迟消息的功能。以下是安装和使用延迟消息插件的步骤: 1. 下载延迟消息插件,可以从GitHub上下载最新版本的插件,例如: ```shell wget https://github.com/rabbitmq/rabbitmq-delayed-message-exchange/releases/download/3.10.2/rabbitmq_delayed_message_exchange-3.10.2.ez ``` 2. 将下载的插件文件复制到RabbitMQ的插件目录中,例如: ```shell cp rabbitmq_delayed_message_exchange-3.10.2.ez /usr/lib/rabbitmq/lib/rabbitmq_server-3.8.0/plugins/ ``` 3. 启用插件,可以使用以下命令启用插件: ```shell rabbitmq-plugins enable rabbitmq_delayed_message_exchange ``` 4. 创建一个延迟消息交换机,可以使用以下命令创建一个延迟消息交换机: ```shell rabbitmqadmin declare exchange name=delayed_exchange type=x-delayed-message arguments='{"x-delayed-type":"direct"}' ``` 5. 发布一个延迟消息,可以使用以下命令发布一个延迟消息: ```shell rabbitmqadmin publish exchange=delayed_exchange routing_key=delayed_queue payload='{"message":"hello world"}' properties='{"headers":{"x-delay":5000}}' ``` 其中,x-delay头部属性指定了延迟时间,单位为毫秒。 6. 消费延迟消息,可以使用普通的消费者来消费延迟消息,例如: ```python import pika connection = pika.BlockingConnection(pika.ConnectionParameters('localhost')) channel = connection.channel() channel.exchange_declare(exchange='delayed_exchange', exchange_type='x-delayed-message', arguments={'x-delayed-type': 'direct'}) result = channel.queue_declare(queue='', exclusive=True) queue_name = result.method.queue channel.queue_bind(exchange='delayed_exchange', queue=queue_name, routing_key='delayed_queue') def callback(ch, method, properties, body): print("Received %r" % body) channel.basic_consume(queue=queue_name, on_message_callback=callback, auto_ack=True) print('Waiting for messages...') channel.start_consuming() ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值