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都能接收到这条消息

相关推荐
掘金-我是哪吒6 小时前
分布式微服务系统架构第156集:JavaPlus技术文档平台日更-Java线程池使用指南
java·分布式·微服务·云原生·架构
亲爱的非洲野猪6 小时前
Kafka消息积压的多维度解决方案:超越简单扩容的完整策略
java·分布式·中间件·kafka
活跃家族6 小时前
分布式压测
分布式
前端世界8 小时前
HarmonyOS开发实战:鸿蒙分布式生态构建与多设备协同发布全流程详解
分布式·华为·harmonyos
DavidSoCool8 小时前
RabbitMQ使用topic Exchange实现微服务分组订阅
分布式·微服务·rabbitmq
掘金-我是哪吒9 小时前
分布式微服务系统架构第158集:JavaPlus技术文档平台日更-JVM基础知识
jvm·分布式·微服务·架构·系统架构
东窗西篱梦10 小时前
Redis集群部署指南:高可用与分布式实践
数据库·redis·分布式
Acrel_Fanny10 小时前
Acrel-1000系列分布式光伏监控系统在湖北荆门一马光彩大市场屋顶光伏发电项目中应用
分布式
xufwind10 小时前
spark standlone 集群离线安装
大数据·分布式·spark
半新半旧11 小时前
Redis集群和 zookeeper 实现分布式锁的优势和劣势
redis·分布式·zookeeper