RabbitMq(1)死信队列、延迟队列

本文介绍了RabbitMQ中如何使用死信队列(DLX)处理消息拒绝和过期的情况,以及如何利用死信队列实现延迟队列功能。在死信队列中,当消息被拒绝、过期或达到最大长度时,会被发送到指定的DLX并绑定到特定的队列。此外,通过设置不同的过期时间,可以创建多个延迟队列,用于在不同时间点投递消息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、死信队列

DLX(Dead Letter Exchange),死信交换器。当队列中的消息被拒绝、或者过期会变成死信,死信可以被重新发布到另一个交换器,这个交换器就是DLX,与DLX绑定的队列称为死信队列。
造成死信的原因:

  • 信息被拒绝
  • 信息超时
  • 超过了队列的最大长度

可以通过设置x-dead-letter-exchange参数指定DLX,设置x-dead-letter-routing-key指定DLX使用的路由键。

Map<String, Object> arg = new HashMap<String, Object>();
// 设置DLX
arg.put("x-dead-letter-exchange", "exchange.dlx");
// 设置DLX路由键,
arg.put("x-dead-letter-routing-key", "routingkey.dlx");
// 设置消息过期时间,消息过期后,会重新发布到DLX
arg.put("x-message-ttl", 5000);
channel.queueDeclare("queue.normal", true, false, false, arg);

代码实现:

public class DLX {
   

	public static void main(String[] args) throws IOException, TimeoutException {
   
		
		ConnectionFactory factory = new ConnectionFactory();
		ConnectionFactory factory = new ConnectionFactory();
		factory.setHost("192.168.79.108");
		factory.setPort(5672
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值