RabbitMQ之主题交换机
RabbitMQ中的交换机大致分为四种,默认,直连(Direct),主题(Topic),扇形(Fanout),其中灵活性最大的应该算是Topic主题交换机了。
主题交换机中的路由键有两个替换符需要大家注意到:
*(星号)可以代替一个单词
#(井号)可以代替零个或多个单词
主题交换机生产者代码
public class EmitLogTopic {
public static final String EXCHANGE_NAME = "topic_logs";
public static void main(String[] args) throws Exception {
Channel channel = RabbitMqUtils.getChannel();
Map<String, String> bindingKeyMap = new HashMap<>();
//map中存放的是不同的routingKey
bindingKeyMap.put("quick.orange.rabbit", "被队列Q1Q2收到");
bindingKeyMap.put("lazy.orange.elephant", "被队列Q1Q2收到");
bindingKeyMap.put("quick.orange.fox", "被队列Q1收到");
bindingKeyMap.put("lazy.brown.fox", "被队列Q2收到");
for (String key : bindingKeyMap.keySet()) {
channel.basicPublish(EXCHANGE_NAME, key, null, bindingKeyMap.get(key).getBytes("UTF-8"));
System.out.println("生产者发出消息:" + bindingKeyMap.get(key));
}
}
}
消费者代码如下:
public class ReceiveLogsTopic01 {
//交换机的名称
public static final String EXCHANGE_NAME = "topic_logs";
//接收消息
public static void main(String[] args) throws Exception {
Channel channel = RabbitMqUtils.getChannel();
//声明交换机
channel.exchangeDeclare(EXCHANGE_NAME, "topic");
//声明队列
channel.queueDeclare("Q1", false, false, false, null);
//这里的routingKey替换规则是当生产者中的routingKey是前面是一个单词,中间是orange,后面是一个
//单词,该消费者就可以接收到该消息。
channel.queueBind("Q1", EXCHANGE_NAME, "*.orange.*");
System.out.println("等待接收消息......");
DeliverCallback deliverCallback = (consumerTag, message) -> {
System.out.println("01控制台接收到消息:" + new String(message.getBody(), "UTF-8"));
System.out.println("接收队列:" + "绑定键:" + message.getEnvelope().getRoutingKey());
};
CancelCallback cancelCallback = (consumerTag) -> {
};
//接收消息
channel.basicConsume("Q1", true, deliverCallback, cancelCallback);
}
}
显示效果图
生产者效果图
消费者效果图
可以看见,消费者只消费中间是orange,并且orange前面后面只有一个单词这种规则的生产者消息。