rabbitMq路由键介绍

rabbitTemplate.convertAndSend() 是 Spring AMQP 中用于发送消息到 RabbitMQ 的方法。下面是对您提供的代码示例的解释:

复制代码
rabbitTemplate.convertAndSend("ums-platform.ex", "ums.report.routing", param);

这行代码主要完成以下几个操作:

复制代码
rabbitTemplate:这是一个 RabbitTemplate 对象,它是 Spring AMQP 提供的用于与 RabbitMQ 进行交互的模板类。在发送消息时,我们使用这个对象来调用相应的方法。

convertAndSend() 方法:这是 RabbitTemplate 类的一个方法,用于将消息发送到指定的交换机和路由键。

"ums-platform.ex":这是交换机的名称,表示要将消息发送到名为 "ums-platform.ex" 的交换机。

"ums.report.routing":这是路由键,表示消息将根据该路由键进行匹配,并被路由到相应的队列。在这个例子中,消息会被发送到与 "ums.report.routing" 路由键匹配的队列中。

param:这是要发送的消息内容,可以是任意类型的对象。

总结起来,上述代码的作用是将 param 对象作为消息发送到名为 "ums-platform.ex" 的交换机,并使用 "ums.report.routing" 路由键进行路由。

请注意,在实际运行代码之前,您需要确保已经正确配置了 RabbitMQ 连接和交换机/队列等相关信息。另外,您还需要在项目中引入 Spring AMQP 相关的依赖。

当使用 "ums.report.routing" 路由键进行路由时,RabbitMQ会将消息发送到与该路由键匹配的队列。下面是一个示例来说明这个过程:

假设我们有以下的交换机和队列配置:

复制代码
交换机名称:"ums-platform.ex"
队列1名称:"ums.report.queue1"
队列2名称:"ums.report.queue2"

我们使用 "ums.report.routing" 路由键进行路由。

首先,我们需要将队列1和队列2绑定到交换机,同时指定它们的路由键:

复制代码
@Bean
public Binding binding1(Queue queue1, DirectExchange exchange) {
    return BindingBuilder.bind(queue1).to(exchange).with("ums.report.routing");
}

@Bean
public Binding binding2(Queue queue2, DirectExchange exchange) {
    return BindingBuilder.bind(queue2).to(exchange).with("ums.report.routing");
}

在上述代码中,binding1 方法将队列1绑定到交换机,并使用 "ums.report.routing" 路由键进行绑定。同样,binding2 方法将队列2绑定到交换机,并使用相同的路由键进行绑定。

然后,我们可以通过以下方式发送消息到交换机,并使用 "ums.report.routing" 路由键进行路由:

复制代码
rabbitTemplate.convertAndSend("ums-platform.ex", "ums.report.routing", message);

在上述代码中,我们使用 rabbitTemplate.convertAndSend() 方法将 message 消息发送到交换机 "ums-platform.ex",并指定路由键为 "ums.report.routing"。

根据上述配置和代码,如果消息发送成功,RabbitMQ 将根据路由键 "ums.report.routing" 将该消息路由到与之匹配的队列。在我们的示例中,消息将被路由到队列1和队列2。

请注意,这只是一个示例,实际使用时您需要确保正确设置交换机、队列以及它们之间的绑定关系,并且确保消费者正确监听相应的队列以接收消息。

相关推荐
深兰科技21 分钟前
深兰科技入选“2025中国人工智能行业创新力企业百强”
人工智能·科技·百度·kafka·rabbitmq·memcached·深兰科技
兜兜风d'24 分钟前
RabbitMQ事务机制详解
数据库·spring boot·分布式·rabbitmq·ruby·java-rabbitmq
9ilk28 分钟前
【仿RabbitMQ的发布订阅式消息队列】--- 模块设计与划分
c++·笔记·分布式·后端·中间件·rabbitmq
勇往直前plus30 分钟前
学习和掌握RabbitMQ及其与springboot的整合实践(篇二)
spring boot·学习·rabbitmq·java-rabbitmq
许泽宇的技术分享4 小时前
当 AI Agent 遇上工作流编排:微软 Agent Framework 的 Workflow 深度解析
人工智能·microsoft
ManageEngine卓豪5 小时前
Azure 监控工具怎么选?从原生局限到第三方解决方案的效率跃升
microsoft·azure·apm·azure监控
小码过河.5 小时前
Rabbitmq扇形队列取消绑定交换机之后任然接收消息问题
分布式·rabbitmq·ruby
许泽宇的技术分享6 小时前
当 AI Agent 遇上 MCP:微软 Agent Framework 的“瑞士军刀“式扩展之道
人工智能·microsoft
Leinwin12 小时前
微软重磅发布开源引擎Microsoft Agent Framework
microsoft·开源
渡我白衣1 天前
C++ 同名全局变量:当符号在链接器中“相遇”
开发语言·c++·人工智能·深度学习·microsoft·语言模型·人机交互