今天介绍rabbitmq的direct方式,可以指定哪一个消费者进行消费。
在Direct模型下:
-
队列与交换机的绑定,不能是任意绑定了,而是要指定一个
RoutingKey
(路由key) -
消息的发送方在 向 Exchange发送消息时,也必须指定消息的
RoutingKey
。 -
Exchange不再把消息交给每一个绑定的队列,而是根据消息的
Routing Key
进行判断,只有队列的Routingkey
与消息的Routing key
完全一致,才会接收到消息。
SpringBoot提供了两种方式声明队列和交换机,一种是基于bean的方式,一种是基于注解的方式,本次采用注解的方式,在开发的过程中,我还是喜欢bean的方式,大家可以根据注解的喜好来决定。
@RabbitListener(bindings = @QueueBinding(
value = @Queue(value = "direct.queue1",durable = "false"),
exchange = @Exchange(name = "direct.exchange1",durable = "false",
type = ExchangeTypes.DIRECT),
key = {"red","blue"}
))
public void directListener1(String msg) {
System.out.println("DirectReceiver消费者1收到消息 : " +msg);
}
@RabbitListener(bindings = @QueueBinding(
value = @Queue(value = "direct.queue2",durable = "false"),
exchange = @Exchange(name = "direct.exchange1",durable = "false",
type = ExchangeTypes.DIRECT),
key = {"red","yellow"}
))
public void directListener2(String msg) {
System.out.println("DirectReceiver消费者2收到消息 : " +msg);
}
看过上篇的小伙伴流程应该很熟悉,先声明队列和交换机,再进行绑定,SpringBoot直接妖魔化注解的方式,将声明和消费者接受放在一起做了,代码还是很简洁的。
编写生产者代码:
@GetMapping("/direct")
public void sendMesssageDirect(String msg,String routingKey) {
rabbitTemplate.convertAndSend("direct.exchange1",routingKey,msg);
}
routingKey被叫做路由键,决定往哪个队列发送消息,在RabbitListener中是key参数指定,可以有多个routingKey。
下面我们开始测试:
当routing只有yellow的时候,只有消费者2收到了消息。
当routing是red的时候两者都收到了消息:
direct方式可以指定我们到哪个消费者消息,决定我们发消息的方向