rabbitMq集成Spring后,消费者设置手动ack,并且在业务上控制是否ack

1. 在这里不提如何集成rabbit mq到Spring。

2. 实现功能的配置都在消费者端:

3. 下面是步骤和说明

(1)在消费者端的mq配置文件上添加,配置  关键代码为 acknowledeg = "manual"
,意为表示该消费者的ack方式为手动(此时的queue已经和生产者的exchange通过某个routeKey绑定了)

[html]  view plain  copy
  1. <rabbit:listener-container connection-factory="connectionFactory" acknowledge="manual">  
  2.     <rabbit:listener queues="queue_xxx" ref="MqConsumer"/>  
  3.     <rabbit:listener queues="queue_xxx" ref="MqConsumer2"/>  
  4. </rabbit:listener-container>  

(2)新建一个类 MqConsumer ,并实现接口  ChannelAwareMessageListener ,实现onMessage方法,不需要指定方法。

因为下方图所示,springAMQP中已经实现了一个功能,如果该监听器已经实现了下面2个接口,则直接调用onMessage方法


(3)关键点在实现了ChannelAwareMessageListener的onMessage方法后,会有2个参数。

一个是message(消息实体),一个是channel就是当前的通道

很多地方都没有说清楚怎么去手动ack,其实手动ack就是在当前channel里面调用basicAsk的方法,并传入当前消息的tagId就可以了。


其中deliveryTag是tag的id,由生产者生成。

第二个参数我其实也没理解用途,暂时还没有模拟出场景,所以先不讨论。

同样的,如果要unack或者拒绝消息(reject)的时候,也是调用channel里面的basicXXX方法就可以了(当然要制定tagId)。

注意如果抛异常或unack(并且requeue为true),消息会一直重新入队列,一不小心就会xxxxx一大堆消息不断重复~。


//消息的标识,false只确认当前一个消息收到,true确认所有consumer获得的消息

channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);

//ack返回false,并重新回到队列,api里面解释得很清楚

channel.basicNack(message.getMessageProperties().getDeliveryTag(), false, true);

//拒绝消息

channel.basicReject(message.getMessageProperties().getDeliveryTag(), true);


暂时讲完,如果有什么补充或纠正欢迎大家指出
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
RabbitMQ中,手动ACKacknowledge)是一种确认消息已被消费者正确处理的方式。通过手动ACK消费者可以控制消息的确认时机,以确保消息被处理完成后再进行确认,以避免消息丢失或重复消费的问题。 根据引用和引用的配置信息,可以看出设置手动ACK的方式是在消费者的配置中添加如下参数: spring.rabbitmq.listener.simple.acknowledge-mode=manual 这样配置后,消费者在消费消息后需要手动调用ACK方法来确认消息的处理结果。这样可以确保消息只有在消费者确认处理完成后才会从队列中删除,避免了消息的丢失。 需要注意的是,在手动ACK模式下,如果消费者没有确认消息,消息将一直被标记为未处理状态,可能会导致消息堆积或重复消费的问题。因此,消费者需要谨慎处理消息并及时确认,以确保消息的可靠处理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [RabbitMQ手动ACK与死信队列](https://blog.csdn.net/QingXu1234/article/details/130904397)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [15.RabbitMQ 消费端手动ACK消息确认机制](https://blog.csdn.net/Stubborn_bull/article/details/118963624)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值