rabbitmq 五种模式

 

 

1、简单模式

简单模式:一个生产者,一个消费者

 

2、工作队列模式

一个生产者,多个消费者,每个消费者获取到的消息唯一(消费者彼此竞争成为接收者)

channel.setbasicQos(1);

 

 

3、发布订阅模式

一个生产者发送的消息会被多个消费者获取。

交换机为fanout

 

 

 

 

 

4、路由模式

发送消息到交换机并且要指定路由key ,消费者将队列绑定到交换机时需要指定路由key

交换机为direct 并指定路由key

 

 

5、topic通配符模式

将路由键和某模式进行匹配,此时队列需要绑定在一个模式上

交换机为topic模式,路由key可选 *(匹配明确的一个单词)  或 #(匹配0到多个单词)

 

 

 

 

手动应答

channel.basicAck();

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

===============================================================

channel.basicNack(delivery.getEnvelope().getDeliveryTag(), falsetrue);

deliveryTag:该消息的index

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

requeue:被拒绝的是否重新入队列

=============================================================

channel.basicReject(delivery.getEnvelope().getDeliveryTag(), false);

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

============================================================

channel.basicConsume(QUEUE_NAME, true, consumer);

autoAck:是否自动ack,如果不自动ack,需要使用channel.ack、channel.nack、channel.basicReject 进行消息应答

注:

channel.basicNack  channel.basicReject 的区别在于basicNack可以拒绝多条消息,而basicReject一次只能拒绝一条消息

 

 

猜你喜欢

转载自blog.csdn.net/Zaric_001/article/details/113697647