RabbitMQ创建死信队列

向Queue_TTL队列里发送消息,10秒后当消息没有被正常消费掉则消息过期被转发至 Queue_DLX死信队列

const amqp = require('amqplib');

async function TTL_production() {
    var conn = await amqp.connect("amqp://localhost:5672");
    var channel = await conn.createChannel();
    var Exchange_TTL = "Exchange_TTL";
    var Queue_TTL = "Queue_TTL";
    var RoutingKey_TTL = "RoutingKey_TTL";
    var Exchange_DLX = 'Exchange_DLX';
    var Queue_DLX = 'Queue_DLX';
    var RoutingKey_DLX = 'RoutingKey_DLX';
    //创建死信队列  这里声明死信队列是为了确保死信队列每次都存在,消息不会丢失
    await channel.assertExchange(Exchange_DLX, 'direct', { autoDelete: true, durable: true });
    await channel.assertQueue(Queue_DLX, {
        exclusive: false,
    });
    await channel.bindQueue(Queue_DLX, Exchange_DLX, RoutingKey_DLX)
    //创建消息队列
    await channel.assertExchange(Exchange_TTL, "direct", { autoDelete: true, durable: true });
    await channel.assertQueue(Queue_TTL, {
        exclusive: false,
        deadLetterExchange: Exchange_DLX,
        deadLetterRoutingKey: RoutingKey_DLX,
    });
    await channel.bindQueue(Queue_TTL, Exchange_TTL, RoutingKey_TTL);
    await channel.publish(Exchange_TTL, RoutingKey_TTL, Buffer.from("发送了一条消息!"), {
        //消息10秒后过期
        expiration: '10000'
    })
    console.log("消息发送成功");
    await channel.close();
    await conn.close();
}

TTL_production();

2. 死信消费者

const amqp = require('amqplib');

async function DLX_comsumer() {
    var conn = await amqp.connect("amqp://localhost:5672");
    var channel = await conn.createChannel();
    var Exchange_DLX = 'Exchange_DLX';
    var Queue_DLX = 'Queue_DLX';
    var RoutingKey_DLX = 'RoutingKey_DLX';
    await channel.assertExchange(Exchange_DLX, 'direct', { autoDelete: true, durable: true });
    await channel.assertQueue(Queue_DLX, {
        exclusive: false,
    });
    await channel.bindQueue(Queue_DLX, Exchange_DLX, RoutingKey_DLX)
    await channel.prefetch(1, false)
    await channel.consume(Queue_DLX, msg => {
        console.log(msg.content.toString())
        channel.ack(msg);
    }, { noAck: false })
    await channel.close();
    await conn.close();
}


DLX_comsumer();

执行生产者向Queue_TTL 发送消息。 

10秒后消息会转发至Queue_DLX 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Spring Boot中配置死信队列(Dead Letter Queue),您可以按照以下步骤进行操作: 1. 添加RabbitMQ依赖:在您的Spring Boot项目的pom.xml文件中,添加RabbitMQ依赖。例如,使用以下Maven依赖项: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 2. 配置RabbitMQ连接信息:在application.properties或application.yml文件中,配置RabbitMQ的连接信息,例如: ```properties spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest ``` 3. 创建交换机和队列:使用RabbitAdmin或通过注解方式,在您的代码中创建交换机和队列。例如,可以使用@Bean注解创建一个RabbitAdmin bean,并在其上使用@PostConstruct注解来创建交换机和队列。 ```java @Bean public RabbitAdmin rabbitAdmin(ConnectionFactory connectionFactory) { return new RabbitAdmin(connectionFactory); } @PostConstruct public void setupQueues() { rabbitAdmin().declareExchange(new DirectExchange("myExchange")); rabbitAdmin().declareQueue(new Queue("myQueue")); rabbitAdmin().declareBinding(new Binding("myQueue", Binding.DestinationType.QUEUE, "myExchange", "myRoutingKey", null)); } ``` 4. 配置死信队列创建一个专用的队列来作为死信队列,并将其与原始队列绑定。您可以在队列声明时设置x-dead-letter-exchange和x-dead-letter-routing-key参数来指定死信队列的交换机和路由键。 ```java @PostConstruct public void setupQueues() { rabbitAdmin().declareExchange(new DirectExchange("myExchange")); rabbitAdmin().declareQueue(new Queue("myQueue", false, false, false, new HashMap<String, Object>() {{ put("x-dead-letter-exchange", "dlxExchange"); put("x-dead-letter-routing-key", "dlxRoutingKey");
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值