RabbitMQ 事务-消费者异步处理
消费者异步处理
- 手动处理方式:消费者收到消息后,手动调用basic.ack/basic.nack/basic.reject后,RabbitMQ收到这些消息后,才认为本次投递成功
- 手动消息确认方法有:
- § basic.ack用于肯定确认
- § basic.nack用于否定确认(注意:这是AMQP 0-9-1的RabbitMQ扩展)
- § basic.reject用于否定确认,但与basic.nack相比有一个限制:一次只能拒绝单条消息
- 消费者端以上的3个方法都表示消息已经被正确投递,但是basic.ack表示消息已经被正确处理,但是basic.nack,basic.reject表示没有被正确处理,但是RabbitMQ中仍然需要删除这条消息。
- 手动的确认模式的投递效率略低于自动,但是可以弥补自动确认模式的不足。
代码示例
import com.rabbitmq.client.*;
import java.io.IOException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ConsumerConfirmRecv {
private final static String QUEUE_NAME = "consumerconfirm";
private final static String EXCHANGE_NAME =AsynConfirmSend.EXCHA