spring-boot | rabbitMq-Topic Exchange

简介: 上篇文章我们主要介绍了rabbitMq的Direct模式,上手比较简单,但是存在一定局限性,不能基于多重条件进行路由选择。今天给大家介绍另外一种比较灵活的方式。主题转发模式(Topic Exchange)。

上篇文章我们主要介绍了rabbitMq的Direct模式,上手比较简单,但是存在一定局限性,不能基于多重条件进行路由选择。今天给大家介绍另外一种比较灵活的方式。主题转发模式(Topic Exchange)。这种模式的优势在于可以根据routing_ke的不同绑定到不同的队列,接收不同的消息。

在发送端增加配置

@Configuration
public class TopicConfig {
        
    //创建两个队列
    @Bean(name = "queuemessage")
    public  Queue queuemessage(){
        return new Queue("topic.message");
        
    }

    
    @Bean(name = "queuemessages")
    public Queue queuemessages(){
        return new Queue("topic.messages");
    }
    
    //创建交换机
    @Bean
    public TopicExchange exchange(){
        return new TopicExchange("exchange");
    }
    
    
    //绑定队列
    @Bean
    Binding binding1(@Qualifier("queuemessage")Queue queuemessage,TopicExchange exchange){
        return BindingBuilder.bind(queuemessage).to(exchange).with("topic.message");
    }
    
    //绑定队列
        @Bean
        Binding binding2(@Qualifier("queuemessages")Queue queuemessages,TopicExchange exchange){
            return BindingBuilder.bind(queuemessages).to(exchange).with("topic.#");
        }
    
}

匹配规则:

星号(*) :只能匹配一个单词
井号(#):可以匹配0个或多个单词

如果一个队列绑定的键为"#"时,将会接收所有的队列,类似于fanout转发器。
如果绑定的队列不包含"#"和"*"时,这时候类似于Direct模式,直接匹配。

接收端绑定指定队列

@Component
public class Receive {

   @RabbitListener(queues="topic.message")    
    public void processC(String obj) {
        System.out.println("receiver:topic.message:"+obj);
    }
    
    @RabbitListener(queues="topic.messages")    
    public void topics(String obj) {
        System.out.println("receiver:topic.messages:"+obj);
    }

}

测试类,一个三个参数,第一个参数是交换机的名字,第二个参数是队列的名字,第三个参数是发送的内容。

Component
public class Sender {
    
    @Autowired
    private AmqpTemplate template;
    
    @Scheduled(cron="0/5 * * * * ? ")   //每5秒执行一次 
    public void send() {
    //User user = new User(1, "张三", "男");
   DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
  template.convertAndSend("exchange","topic.message",sdf.format(new Date())+"主题转发模式!");

    }
    
}

当我们将队列名字设置为topic.message的时候,看下控制台发现,同一时间发送的消息会同时被两个队列接收。




我们再将队列名字设置为topic.test看一下

@Component
public class Sender {
    
    @Autowired
    private AmqpTemplate template;
    
    @Scheduled(cron="0/5 * * * * ? ")   //每5秒执行一次 
    public void send() {
    //User user = new User(1, "张三", "男");
        DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
    template.convertAndSend("exchange","topic.test",sdf.format(new Date())+"主题转发模式!");
    }
    
}

发现只有topic.#匹配到了队列,到这里Topic Exchange以整合完毕。我会继续整合其他模式。



(未完待续)

相关实践学习
快速体验阿里云云消息队列RocketMQ版
本实验将带您快速体验使用云消息队列RocketMQ版Serverless系列实例进行获取接入点、创建Topic、创建订阅组、收发消息、查看消息轨迹和仪表盘。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
5月前
|
消息中间件 Java Kafka
消息队列比较:Spring 微服务中的 Kafka 与 RabbitMQ
本文深入解析了 Kafka 和 RabbitMQ 两大主流消息队列在 Spring 微服务中的应用与对比。内容涵盖消息队列的基本原理、Kafka 与 RabbitMQ 的核心概念、各自优势及典型用例,并结合 Spring 生态的集成方式,帮助开发者根据实际需求选择合适的消息中间件,提升系统解耦、可扩展性与可靠性。
356 1
消息队列比较:Spring 微服务中的 Kafka 与 RabbitMQ
|
5月前
|
消息中间件 存储 Java
RabbitMQ 和 Spring Cloud Stream 实现异步通信
本文介绍了在微服务架构中,如何利用 RabbitMQ 作为消息代理,并结合 Spring Cloud Stream 实现高效的异步通信。内容涵盖异步通信的优势、RabbitMQ 的核心概念与特性、Spring Cloud Stream 的功能及其与 RabbitMQ 的集成方式。通过这种组合,开发者可以构建出具备高可用性、可扩展性和弹性的分布式系统,满足现代应用对快速响应和可靠消息传递的需求。
303 2
RabbitMQ 和 Spring Cloud Stream 实现异步通信
|
9月前
|
消息中间件 缓存 NoSQL
基于Spring Data Redis与RabbitMQ实现字符串缓存和计数功能(数据同步)
总的来说,借助Spring Data Redis和RabbitMQ,我们可以轻松实现字符串缓存和计数的功能。而关键的部分不过是一些"厨房的套路",一旦你掌握了这些套路,那么你就像厨师一样可以准备出一道道饕餮美食了。通过这种方式促进数据处理效率无疑将大大提高我们的生产力。
296 32
|
消息中间件 Java 网络架构
|
消息中间件 监控 Java
如何将Spring Boot + RabbitMQ应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot + RabbitMQ应用程序部署到Pivotal Cloud Foundry (PCF)
338 6
|
消息中间件 Java 测试技术
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
这篇文章是关于如何在SpringBoot应用中整合RabbitMQ的消息中间件。内容包括了在SpringBoot项目中添加RabbitMQ的依赖、配置文件设置、启动类注解,以及如何通过单元测试来创建交换器、队列、绑定,并发送和接收消息。文章还介绍了如何配置消息转换器以支持对象的序列化和反序列化,以及如何使用注解`@RabbitListener`来接收消息。
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
|
消息中间件 Java RocketMQ
微服务架构师的福音:深度解析Spring Cloud RocketMQ,打造高可靠消息驱动系统的不二之选!
【8月更文挑战第29天】Spring Cloud RocketMQ结合了Spring Cloud生态与RocketMQ消息中间件的优势,简化了RocketMQ在微服务中的集成,使开发者能更专注业务逻辑。通过配置依赖和连接信息,可轻松搭建消息生产和消费流程,支持消息过滤、转换及分布式事务等功能,确保微服务间解耦的同时,提升了系统的稳定性和效率。掌握其应用,有助于构建复杂分布式系统。
421 0
|
消息中间件 Java 数据安全/隐私保护
Spring Boot与RabbitMQ的集成
Spring Boot与RabbitMQ的集成
|
消息中间件 Java RocketMQ
Spring Boot与RocketMQ的集成
Spring Boot与RocketMQ的集成
|
消息中间件 Java Spring
实现Spring Boot与RabbitMQ消息中间件的无缝集成
实现Spring Boot与RabbitMQ消息中间件的无缝集成

热门文章

最新文章