👽System.out.println(“👋🏼嗨,大家好,我是代码不会敲的小符,双非大四,Java实习中…”);
📚System.out.println(“🎈如果文章中有错误的地方,恳请大家指正!共同进步,共同成长✊”);
🌟System.out.println(“💡如果文章对您有所帮助,希望您可以三连支持一下博主噢🔥”);
🌈System.out.println("🚀正在完成计划中:接下来的三个月里,对梦想的追逐 ");
Topic 交换机
TopicExchange 与 DirectExchange 类似,区别在于 routingKey 可以是多个单词的列表,并且以 . 分割。
Queue与Exchange指定BindingKey时可以使用通配符
- #:代指0个或多个单词
- *:代指一个单词
模拟使用
利用SpringAMQP演示DirectExchange的使用,需求如下
- 在RabbitMQ控制台中,声明队列topic.queue1和topic.queue2
- 在RabbitMQ控制台中,声明交换机hmall.topic,将两个队列与其绑定
- 在consumer服务中,编写两个消费者方法,分别监听topic.queue1和topic.queue2
- 在publisher中编写测试方法,利用不同的 RoutingKey 向 topicTest.topic 发送消息
发送者(生产者)
@SpringBootTest
public class SpringAmqpTest {
@Autowired
private RabbitTemplate rabbitTemplate;
@Test
public void testSendMessage2TopicQueue1() {
String exchangeName = "topicTest.topic";
String msg = "hello, exchangeName_topicTest, message: china.news ...! ";
rabbitTemplate.convertAndSend(exchangeName, "china.news", msg);
}
@Test
public void testSendMessage2TopicQueue2() {
String exchangeName = "topicTest.topic";
String msg = "hello, exchangeName_topicTest, message: other.news ...! ";
rabbitTemplate.convertAndSend(exchangeName, "other.news", msg);
}
}
消费者
@Component
@Slf4j
public class RabbitMqListener {
@RabbitListener(queues = "topic.queue1")
public void listenTopicQueueMessage1(String msg) {
// routing key 为 china.#
log.info("topicConsumer1 accept message: {}", msg);
log.info("topicConsumer1 message success!");
}
@RabbitListener(queues = "topic.queue2")
public void listenTopicQueueMessage2(String msg) {
// routing key 为 #.news
log.info("topicConsumer2 accept message: {}", msg);
log.info("topicConsumer2 message success!");
}
}
交换机的作用
- 接收publisher发送的消息
- 将消息按照规则路由到与之绑定的队列
- Topic Exchange 将消息路由转发到 BindingKey 与消息 RoutingKey 相匹配的队列。【RoutingKey可以是多个单词,以.分割,通配符匹配】
- Topic Exchange 适用于多样化的应用场景,特别是在需要将消息基于不同的主题动态路由到不同队列的情况下非常有用。
最后
慢慢的来,别着急!学会有质量的走过每一步
我是代码不会敲的小符,希望认识更多有经验的大佬,也在努力摸索出自己的道路
欢迎添加小符微信:A13781678921,一起加油