整理好了!2024年最常见 20 道 Rocket MQ面试题(四)

上一篇地址:整理好了!2024年最常见 20 道 Rocket MQ面试题(三)-CSDN博客

七、RocketMQ消费模式有几种?

RocketMQ 提供了两种主要的消费模式,分别是:

  1. 集群消费模式(Clustering):在这种模式下,同一Topic下的消息被分发到同一个ConsumerGroup中的不同实例进行消费,但任意一条消息只会被该组中的一个消费者实例消费。这种方式可以提高消费的并发性,适用于大多数消息业务场景。

  2. 广播消费模式(Broadcasting):在广播消费模式中,同一Topic下的消息会被发送给同一个ConsumerGroup中的所有消费者实例,每个实例都会独立消费所有的消息。这种模式适用于需要将消息分发到多个消费者进行处理的场景,例如日志收集等。

这两种消费模式的选择取决于具体的业务需求和场景。集群消费模式可以有效地提高消息处理的效率和吞吐量,而广播消费模式则可以确保消息被多个消费者实例独立处理。

八、RocketMQ消费消息是push还是pull?

RocketMQ 支持两种消息消费方式:Push(推模式)和 Pull(拉模式)。不过,RocketMQ 主要采用的是 Push 模式,但也提供了 Pull 模式的实现。

Push 模式(推模式)

Push 模式是 RocketMQ 默认的消费方式。在这种模式下,Broker 会主动将消息推送给消费者。这种方式的好处是消费者不需要主动去查询消息,从而简化了消费逻辑,并且可以减少消费者的资源消耗。Push 模式适用于大多数场景,特别是当消费者处理能力有限,或者希望简化消费逻辑时。

RocketMQ 的 Push 模式实际上是一种伪 Push 模式,它底层是基于 Pull 模式实现的,但对外表现出 Push 的特性。RocketMQ 使用长轮询机制来实现这种伪 Push 模式,具体流程如下:

  1. 消费者发送拉取请求到 Broker。
  2. 如果 Broker 上没有消息,消费者的请求会被挂起,直到有新消息到达。
  3. 一旦有新消息到达,Broker 会唤醒挂起的请求,并返回消息给消费者。

Pull 模式(拉模式)

Pull 模式是另一种消费方式,消费者需要主动去 Broker 查询并拉取消息。这种方式的优点是消费者可以根据自身的消费能力来控制拉取消息的频率和数量,从而更好地管理资源和避免过度消费。Pull 模式适用于消费者需要精细控制消息消费速率的场景。

在 RocketMQ 中,Pull 模式的实现涉及到以下步骤:

  1. 消费者调用 PullKernelImpl 发送拉取请求,并指定 Broker 挂起的最长时间。
  2. Broker 中的 PullMessageProcess 处理拉取请求,从 ConsumeQueue 中查询消息。
  3. 如果没有查询到消息,并且启用了长轮询,请求会被挂起,直到有新数据时再返回给消费者。
  4. 一旦有新消息,Broker 会唤醒挂起的拉取请求,并将消息返回给消费者。

总结来说,RocketMQ 主要采用的是 Push 模式,但也提供了 Pull 模式的实现,用户可以根据自己的需求选择合适的消费方式。

  • 17
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RocketMQ是一个分布式消息传递平台,它可以在高吞吐量、低延迟和高可靠性的条件下传递大量的消息。下面是搭建RocketMQ的步骤: 1. 安装JDK RocketMQ需要使用JDK 1.8或更高版本。如果未安装,请先下载并安装JDK。 2. 下载RocketMQ 从官方网站下载RocketMQ的源代码(https://rocketmq.apache.org/release_notes/release-notes-4.9.1/)或者预编译版本。 3. 安装NameServer NameServer是RocketMQ的核心组件之一,它用于管理所有的Broker,包括Broker的路由信息、Topic、Consumer等。 解压下载的RocketMQ文件,进入bin目录,执行以下命令: ``` sh mqnamesrv ``` 4. 安装Broker Broker是RocketMQ的另一个核心组件,它用于存储和分发消息。一个Broker可以管理多个Topic,每个Topic可以有多个Queue。 解压下载的RocketMQ文件,进入bin目录,执行以下命令: ``` sh mqbroker -n localhost:9876 ``` 其中,localhost:9876是NameServer的地址,默认端口为9876。 5. 发送和接收消息 使用RocketMQ的API可以发送和接收消息。以下是一个简单的例子: ``` public class Producer { public static void main(String[] args) throws Exception { DefaultMQProducer producer = new DefaultMQProducer("example_group"); producer.setNamesrvAddr("localhost:9876"); producer.start(); Message message = new Message("example_topic", "Hello RocketMQ".getBytes()); SendResult result = producer.send(message); System.out.println(result); producer.shutdown(); } } public class Consumer { public static void main(String[] args) throws Exception { DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("example_group"); consumer.setNamesrvAddr("localhost:9876"); consumer.subscribe("example_topic", "*"); consumer.registerMessageListener((MessageListenerConcurrently) (messages, context) -> { System.out.println(messages); return ConsumeConcurrentlyStatus.CONSUME_SUCCESS; }); consumer.start(); } } ``` 这个例子中,Producer向example_topic发送一条消息,Consumer从example_topic接收并打印出来。在运行Producer和Consumer之前,确保NameServer和Broker已经启动。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值