RabbitMQ - 06 - Topic交换机

目录

控制台创建队列与交换机

编写消费者方法

编写生产者测试方法

结果


Topic交换机与Direct交换机基本一致

可参考 这篇帖子 http://t.csdnimg.cn/AuvoK

topic交换机与Direct交换机的区别是

  • Topic交换机接收的消息RoutingKey必须是多个单词,以 . 分割

  • Topic交换机与队列绑定时的bindingKey可以指定通配符

  • #:代表0个或多个词

  • *:代表1个词

实现Topic交换机

控制台创建队列与交换机

创建两个队列

创建topic交换机

绑定队列和交换机

注意routing key 一个是 china 开头 一个是news结尾

编写消费者方法

java 复制代码
package cn.itcast.mq.lintener;

import lombok.extern.slf4j.Slf4j;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;

@Slf4j
@Component
public class MQListener {

    @RabbitListener(queues = "topic.queue1")
    public void listenTopicQueue1(String message)  {
        log.info("消费者1收到了消息:........... {}", message);
//        System.out.println("消费者收到了消息: " + message);
    }

    @RabbitListener(queues = "topic.queue2")
    public void listenTopicQueue2(String message)  {
        log.info("消费者2收到了消息: {}", message);
//        System.out.println("消费者收到了消息: " + message);
    }

}

编写生产者测试方法

java 复制代码
package cn.itcast.mq.helloworld;

import org.apache.logging.log4j.message.Message;
import org.junit.jupiter.api.Test;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.messaging.converter.StringMessageConverter;

@SpringBootTest
public class SpringAMQPTest {

    @Autowired
    private RabbitTemplate rabbitTemplate;

    //  topic交换机
    @Test
    void testTopicExchange(){
        String exchangeName = "hmall.topic";
        String message = "hello, topic";
        rabbitTemplate.convertAndSend(exchangeName,"china.news",message);
    }

}

结果

发送了一条消息,两个消息队列都获取到了,

因为发送者的routing key刚好满足两个消息队列的要求,因此这两个queue都能接收到这条消息

相关推荐
ACP广源盛139246256733 小时前
GSV5600@ACP#多接口协议转换芯片,物理 AI 便携终端的互联核心
大数据·人工智能·分布式·嵌入式硬件·spark
极客先躯8 小时前
高级java每日一道面试题-2026年02月12日-实战篇[Docker]-什么是容器的 Seccomp 配置?如何自定义?
java·运维·分布式·docker·容器·自动化·文件
Francek Chen8 小时前
【大数据处理与分析】MapReduce:06 MapReduce编程实践
大数据·hadoop·分布式·mapreduce
小马爱打代码8 小时前
Kafka消息队列监控:Topic积压、吞吐量、Broker负载及消费者组全观测
分布式·kafka
半夜修仙8 小时前
延迟队列的介绍及常见问题
java·数据库·中间件·rabbitmq
轻口味8 小时前
轻规划鸿蒙开发实战10:分布式数据同步深度博弈,UserId 隔离与并发数据冲突消解机
分布式·华为·harmonyos·鸿蒙
Solis程序员9 小时前
Raft:分布式系统的定海神针
java·分布式·kafka·rabbitmq·agent·raft
手握风云-9 小时前
一条消息的旅程:RabbitMQ 学习与实践(一)
中间件·rabbitmq
我是一颗柠檬9 小时前
【Java项目技术亮点】Leaf号段模式双Buffer优化
java·开发语言·分布式·后端·架构
芒鸽9 小时前
HarmonyOS 分布式开发实战:设备协同、数据共享与跨设备迁移
分布式·wpf·harmonyos