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。

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

相关推荐
q***4642 小时前
RabbitMQ高级特性----生产者确认机制
分布式·rabbitmq
小高学习java2 小时前
Canal、Elasticsearch、RabbitMq构建高可用、高性能的异构数据同步方案(亲测可用!!!!)
大数据·elasticsearch·rabbitmq·java-rabbitmq
2501_941624333 小时前
云计算与企业数字化转型:从基础设施到创新引擎
rabbitmq
百***48073 小时前
RabbitMQ 客户端 连接、发送、接收处理消息
分布式·rabbitmq·ruby
2501_941145853 小时前
边缘计算与物联网:未来智能城市的基础设施
rabbitmq
zl9798995 小时前
RabbitMQ-发布确认高级
java·分布式·rabbitmq
百***58845 小时前
MacOS升级ruby版本
开发语言·macos·ruby
MC丶科5 小时前
Spring Boot + RabbitMQ 实现异步消息处理(订单通知、邮件发送)!告别同步阻塞“噩梦”
spring boot·rabbitmq·java-rabbitmq
喝养乐多长不高5 小时前
RabbitMQ:消息确认
java·rabbitmq·java-rabbitmq
tanxinji10 小时前
RabbitMQ四种交换器类型详解及示例
java·rabbitmq