RabbitMQ中的消息发布-订阅模式是什么?如何实现?

简介: RabbitMQ中的消息发布-订阅模式是什么?如何实现?

RabbitMQ中的消息发布-订阅模式是什么?如何实现?

RabbitMQ中的消息发布-订阅模式是一种常见的消息传递模式,用于将消息广播给多个消费者。在这种模式下,一个生产者将消息发送到一个交换机(Exchange),而交换机将消息广播给所有与之绑定的队列(Queue)。每个队列都有一个消费者来接收消息并进行处理。

下面是一个使用Java代码实现RabbitMQ消息发布-订阅模式的示例:

首先,我们需要创建一个连接工厂,并设置RabbitMQ服务器的主机地址。然后,使用连接工厂创建一个连接,并使用连接创建一个通道。接着,我们声明一个交换机,并将交换机的类型设置为fanout,表示消息将被广播到所有与之绑定的队列。

// 创建连接工厂
ConnectionFactory factory = new ConnectionFactory();
factory.setHost("localhost");
// 创建连接
Connection connection = factory.newConnection();
// 创建通道
Channel channel = connection.createChannel();
// 声明交换机
channel.exchangeDeclare("my_exchange", "fanout");

在声明交换机时,我们需要指定交换机的名称和类型。这里我们将交换机的名称设置为my_exchange,类型设置为fanout。

然后,我们可以通过调用basicPublish方法来发送消息到交换机。在发送消息时,我们需要将交换机的名称设置为目标交换机的名称,并将routingKey参数设置为空字符串。

String message = "Hello, RabbitMQ!";
channel.basicPublish("my_exchange", "", null, message.getBytes());

在上述代码中,我们将交换机的名称设置为my_exchange,表示消息将被广播到与之绑定的所有队列。

接下来,我们可以创建多个队列,并将这些队列绑定到交换机上。每个队列都有一个消费者来接收消息并进行处理。

// 创建队列并绑定到交换机
String queueName1 = channel.queueDeclare().getQueue();
channel.queueBind(queueName1, "my_exchange", "");
String queueName2 = channel.queueDeclare().getQueue();
channel.queueBind(queueName2, "my_exchange", "");

在上述代码中,我们使用queueDeclare方法创建一个匿名队列,并获取队列的名称。然后,我们使用queueBind方法将队列绑定到交换机上,将交换机的名称设置为my_exchange,routingKey参数设置为空字符串。

最后,我们可以通过消费者来接收消息。在消费者中,我们需要使用basicConsume方法来指定要消费的队列和消息处理逻辑。

channel.basicConsume(queueName1, true, new DefaultConsumer(channel) {
    @Override
    public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
        String message = new String(body, "UTF-8");
        System.out.println("Received message from queue 1: " + message);
    }
});
channel.basicConsume(queueName2, true, new DefaultConsumer(channel) {
    @Override
    public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
        String message = new String(body, "UTF-8");
        System.out.println("Received message from queue 2: " + message);
    }
});

在上述代码中,我们使用basicConsume方法来指定要消费的队列,将队列的名称设置为queueName1和queueName2,并传入一个自定义的DefaultConsumer对象。在handleDelivery方法中,我们可以处理接收到的消息。

通过以上步骤,我们就可以实现RabbitMQ中的消息发布-订阅模式。生产者将消息发送到交换机,交换机将消息广播给所有与之绑定的队列,每个队列都有一个消费者来接收并处理消息。

需要注意的是,消息发布-订阅模式中的消息是广播给所有队列的,因此每个队列都会接收到相同的消息。如果需要实现消息的点对点传递,可以使用RabbitMQ的消息路由模式。

相关实践学习
快速体验阿里云云消息队列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
相关文章
|
消息中间件 监控 数据挖掘
【有奖实践】轻量消息队列(原 MNS)订阅 OSS 事件实时处理文件变动
当你需要对对象存储 OSS(Object Storage Service)中的文件变动进行实时处理、同步、监听、业务触发、日志记录等操作时,你可以通过设置 OSS 的事件通知规则,自定义关注的文件,并将 OSS 事件推送到轻量消息队列(原 MNS)的队列或主题中,开发者的服务即可及时收到相关通知,并通过消费消息进行后续的业务处理。
367 101
|
消息中间件
RabbitMQ的 RPC 消息模式你会了吗?
【9月更文挑战第11天】RabbitMQ 的 RPC(远程过程调用)消息模式允许客户端向服务器发送请求并接收响应。其基本原理包括:1) 客户端发送请求,创建回调队列并设置关联标识符;2) 服务器接收请求并发送响应至回调队列;3) 客户端根据关联标识符接收并匹配响应。实现步骤涵盖客户端和服务器的连接、信道创建及请求处理。注意事项包括关联标识符唯一性、回调队列管理、错误处理及性能考虑。RPC 模式适用于构建可靠的分布式应用程序,但需根据需求调整优化。
560 3
|
消息中间件 对象存储
轻量消息队列(原 MNS)订阅 OSS 事件实践
使用轻量消息队列订阅OSS事件,实时处理文件变动,赢取ins风U型枕(限量500个)。访问活动页面,完成实操并上传截图即可参与领奖。活动时间:即日起至2025年2月28日16:00。奖品数量有限,先到先得,快来报名吧!
379 2
|
消息中间件 网络协议 RocketMQ
RocketMQ Controller 模式 始终更新成本机ip
ontrollerAddr=192.168.24.241:8878 但是日志输出Update controller leader address to 127.0.0.1:8878。导致访问失败
412 4
|
消息中间件 测试技术
通过轻量消息队列(原MNS)主题HTTP订阅+ARMS实现自定义数据多渠道告警
轻量消息队列(原MNS)以其简单队列模型、轻量化协议及按量后付费模式,成为阿里云产品间消息传输首选。本文通过创建主题、订阅、配置告警集成等步骤,展示了该产品在实际应用中的部分功能,确保消息的可靠传输。
443 2
|
消息中间件 应用服务中间件 网络安全
rabbitMQ镜像模式搭建
rabbitMQ镜像模式搭建
|
消息中间件 开发者
【RabbitMQ深度解析】Topic交换器与模式匹配:掌握消息路由的艺术!
【8月更文挑战第24天】在消息队列(MQ)体系中,交换器作为核心组件之一负责消息路由。特别是`topic`类型的交换器,它通过模式匹配实现消息的精准分发,适用于发布-订阅模式。不同于直接交换器和扇形交换器,`topic`交换器支持更复杂的路由策略,通过带有通配符(如 * 和 #)的模式字符串来定义队列与交换器间的绑定关系。
573 2
|
消息中间件
RabbitMQ广播模式
RabbitMQ广播模式
511 1
|
消息中间件 存储 Kafka
MetaQ/RocketMQ 原理问题之RocketMQ DLedger融合模式的问题如何解决
MetaQ/RocketMQ 原理问题之RocketMQ DLedger融合模式的问题如何解决
275 2
|
消息中间件 传感器 负载均衡
消息队列 MQ使用问题之如何配置一主一从的同步复制模式
消息队列(MQ)是一种用于异步通信和解耦的应用程序间消息传递的服务,广泛应用于分布式系统中。针对不同的MQ产品,如阿里云的RocketMQ、RabbitMQ等,它们在实现上述场景时可能会有不同的特性和优势,比如RocketMQ强调高吞吐量、低延迟和高可用性,适合大规模分布式系统;而RabbitMQ则以其灵活的路由规则和丰富的协议支持受到青睐。下面是一些常见的消息队列MQ产品的使用场景合集,这些场景涵盖了多种行业和业务需求。
消息队列 MQ使用问题之如何配置一主一从的同步复制模式