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。

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

相关推荐
优秀的老黄12 分钟前
Docker部署RabbitMQ
linux·运维·docker·中间件·容器·centos·rabbitmq
java1234_小锋1 小时前
RabbitMQ如何实现消息的持久化?
java·rabbitmq·java-rabbitmq
零点零一2 小时前
`vcpkg` 微软开源的 C/C++ 包管理工具的使用和安装使用spdlog
c语言·c++·microsoft
许泽宇的技术分享4 小时前
微软图引擎GraphEngine深度解析:分布式内存计算的技术革命
分布式·microsoft
AD钙奶-lalala8 小时前
RabbitMQ的核心使用示例
java·rabbitmq·java-rabbitmq
山城码农笑松哥8 小时前
国产凝思debian系Linux离线安装rabbitmq教程步骤
linux·debian·rabbitmq
小句8 小时前
RabbitMQ对接MQTT消息发布指南
分布式·rabbitmq·ruby
数字冰雹9 小时前
图观 应用编辑器 产品介绍
microsoft·编辑器
JAVA学习通9 小时前
【RabbitMQ】高级特性:持久性·发送方确认·重试机制·TTL·死信队列·延迟队列·事务·消息分发
分布式·rabbitmq
海阔天空在前走9 小时前
MQ防止重复消费的四种方法
分布式·rabbitmq