springboot + rabbitmq ack

本文介绍如何在SpringBoot项目中配置RabbitMQ消费者进行手动消息确认(Ack)。通过设置spring.rabbitmq.listener.*.acknowledge-mode为manual,消费者可以使用channel.basicAck、channel.basicNack和channel.basicReject来确认、批量确认或拒绝消息。

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

springboot + rabbitmq 消费者消息确认 (Ack)

开启消息确认

spring.rabbitmq.listener.direct.acknowledge-mode=manual
spring.rabbitmq.listener.simple.acknowledge-mode=manual
消费者

@Component
public class RabbitMqComponent7 {

@RabbitListener(queues = "queueAck")
public void listerQueueR1(Channel channel,String message,@Header(AmqpHeaders.DELIVERY_TAG) long tag) throws IOException {

	System.out.print(message);
	channel.basicAck(tag,false);
}

}

channel.basicAck(deliveryTag, false);

deliveryTag:该消息的index
multiple:是否批量.true:将一次性ack所有小于deliveryTag的消息。

channel.basicNack(deliveryTag, false, true);

deliveryTag:该消息的index
multiple:是否批量.true:将一次性拒绝所有小于deliveryTag的消息。
requeue:被拒绝的是否重新入队列

channel.basicReject(deliveryTag:, false);

deliveryTag:该消息的index
requeue:被拒绝的是否重新入队列

------------------------------------------------------

basicAck:成功消费,消息从队列中删除
basicNack:requeue=true,消息重新进入队列,false被删除
basicReject:等同于basicNack
basicRecover:消息重入队列,requeue=true,发送给新的consumer,false发送给相同的consumer

### Spring Boot 中 RabbitMQ 的消息确认 (ACK) 机制 #### 配置 `application.yml` 文件中的 RabbitMQ 参数 为了启用消息的手动确认模式,在 `application.yml` 或 `application.properties` 文件中需指定相应的配置项。具体来说,通过设置 `acknowledge-mode: manual` 来开启消费端的手动应答功能[^4]。 ```yaml spring: rabbitmq: listener: simple: acknowledge-mode: manual # 设置为手动确认方式 ``` #### 创建监听器类并处理接收到的消息 当应用程序作为消费者接收到来自 RabbitMQ 的消息时,可以通过实现 `ChannelAwareMessageListener` 接口来定义具体的业务逻辑以及执行 ACK 操作的方法。下面是一个简单的例子: ```java import org.springframework.amqp.core.Message; import org.springframework.amqp.rabbit.listener.api.ChannelAwareMessageListener; import com.rabbitmq.client.Channel; public class MyMessageListener implements ChannelAwareMessageListener { @Override public void onMessage(Message message, Channel channel) throws Exception { try { String msg = new String(message.getBody()); System.out.println("Received message: " + msg); // 处理业务逻辑 // 手动确认消息已被成功处理 channel.basicAck(message.getMessageProperties().getDeliveryTag(), false); } catch (Exception e) { // 如果发生异常,则拒绝该条消息,并决定是否重新入队 channel.basicNack(message.getMessageProperties().getDeliveryTag(), false, true); } } } ``` 在此代码片段中,每当有新消息到达时都会触发 `onMessage()` 方法;如果一切正常则调用 `basicAck()` 进行确认,反之则会调用 `basicNack()` 表明存在问题[^2]。 #### 发送测试消息验证效果 最后一步是在控制器或其他地方编写发送消息的功能以便于测试整个流程。可以创建一个 RESTful API 端点用于向队列推送数据,例如: ```java @RestController @RequestMapping("/send") public class MessageController { private final AmqpTemplate amqpTemplate; @Autowired public MessageController(AmqpTemplate amqpTemplate){ this.amqpTemplate = amqpTemplate; } @GetMapping public ResponseEntity<String> sendMessage(@RequestParam String message){ amqpTemplate.convertAndSend("exchangeName", "routingKey", message); return ResponseEntity.ok("Sent"); } } ``` 此时启动应用并通过浏览器或 Postman 访问 `/send?message=HelloRabbitMQ` 即可完成一次完整的交互过程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值