rabbitMq集成Spring后,消费者设置手动ack,并且在业务上控制是否ack
来源:互联网 发布:尤克里里软件哪个好 编辑:程序博客网 时间:2024/06/13 02:56
1. 在这里不提如何集成rabbit mq到Spring。
2. 实现功能的配置都在消费者端:
3. 下面是步骤和说明
(1)在消费者端的mq配置文件上添加,配置 关键代码为 acknowledeg = "manual"
,意为表示该消费者的ack方式为手动(此时的queue已经和生产者的exchange通过某个routeKey绑定了)
(2)新建一个类 MqConsumer ,并实现接口 ChannelAwareMessageListener ,实现onMessage方法,不需要指定方法。
因为下方图所示,springAMQP中已经实现了一个功能,如果该监听器已经实现了下面2个接口,则直接调用onMessage方法
(3)关键点在实现了ChannelAwareMessageListener的onMessage方法后,会有2个参数。
一个是message(消息实体),一个是channel就是当前的通道
很多地方都没有说清楚怎么去手动ack,其实手动ack就是在当前channel里面调用basicAsk的方法,并传入当前消息的tagId就可以了。
第二个参数我其实也没理解用途,暂时还没有模拟出场景,所以先不讨论。
同样的,如果要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);
- rabbitMq集成Spring后,消费者设置手动ack,并且在业务上控制是否ack
- rabbitMq集成Spring后,消费者设置手动ack,并且在业务上控制是否ack
- rabbitMq集成Spring后,消费者设置手动ack,并且在业务上控制是否ack
- rabbitmq 手动ack 代码配置
- StringBoot集成Rabbit,根据业务返回ACK
- StringBoot集成Rabbit,根据业务返回ACK
- StringBoot集成Rabbit,根据业务返回ACK
- ACK
- RabbitMQ消息队列:ACK机制
- RabbitMQ消息应答------ack机制
- RabbitMQ消息队列:ACK机制
- RabbitMQ的ack与nack
- rabbitMq消费者角度:消息分发、消息应答(ACK)、公平分发
- TCP之Delay ACK在Linux和Windows上实现的异同-Linux的自适应ACK
- (六) RabbitMQ消息应答------ack机制
- RabbitMQ入门教程(十二):消息确认Ack
- RabbitMQ与spring集成,配置完整的生产者和消费者
- 关于 RabbitMQ 中 consumer 侧的 ack 属性分析
- 程序设计原则
- android 性能测试基础知识系列1
- 数据结构之线性表(顺序表)的基本操作
- LightOJ 1274 Beating the Dataset (概率dp)
- HDU 2093 考试排名
- rabbitMq集成Spring后,消费者设置手动ack,并且在业务上控制是否ack
- c++之构造函数和析构函数
- 02--Mysql安装、配置、卸载
- 正则表达式总结实例
- hibernate检索策略
- Matlab数值计算示例: 牛顿插值法、LU分解法、拉格朗日插值法、牛顿插值法
- 对于Java中Set、List、Map的一些总结
- Java中从键盘输入多个整数
- 郁闷的c小加(一)