手记

RocketMQ项目开发教程:新手入门指南

概述

本文提供了详细的RocketMQ项目开发教程,涵盖了环境搭建、快速安装与启动、基本概念与架构、消息发送与接收、消息消费模型、消息过滤与路由以及实战与最佳实践等方面的内容。通过这些教程,你可以全面了解并掌握RocketMQ的开发与应用,实现高效的消息传递和处理。

RocketMQ简介与环境搭建
RocketMQ简介

RocketMQ是由阿里巴巴开源的一款分布式消息中间件,具备高吞吐量、低延迟、高可用性等特点。RocketMQ主要应用于大规模分布式系统中,可以实现异步解耦、流量削峰、日志收集、监控等场景。RocketMQ支持多种消息类型,包括普通消息、定时消息、顺序消息、事务消息等,能够很好地支持企业级应用。

开发环境准备

为了搭建RocketMQ开发环境,你需要安装Java开发工具包(JDK)和Maven。RocketMQ官方推荐使用JDK 8或更高版本,Maven 3.0及以上版本。

安装JDK

  1. 访问Oracle官方网站下载JDK,选择合适的版本,例如JDK 8。
  2. 双击下载的安装包,按照安装向导完成安装。
  3. 设置环境变量,编辑系统环境变量,设置JAVA_HOME环境变量指向JDK的安装路径,并将JAVA_HOME%JAVA_HOME%\bin添加到Path环境变量中。

安装Maven

  1. 访问Maven官方网站下载Maven,选择合适的版本,例如Maven 3.6.3。
  2. 解压下载的压缩包,将解压后的目录复制到C:\Program Files目录下。
  3. 设置环境变量,编辑系统环境变量,设置MAVEN_HOME环境变量指向Maven的安装路径,并将%MAVEN_HOME%\bin添加到Path环境变量中。

验证安装
打开命令行窗口,输入java -versionmvn -version,检查是否安装成功。

RocketMQ快速安装与启动

RocketMQ的安装有两种方式:单机模式和集群模式。这里我们将演示单机模式的安装与启动。

  1. 下载RocketMQ。
    • 访问RocketMQ官方GitHub仓库下载最新的源码压缩包,解压到指定目录,例如D:\rocketmq-4.7.0
  2. 启动NameServer。
    • 打开命令行窗口,切换到D:\rocketmq-4.7.0\bin目录,输入mqnamesrv命令启动NameServer。
    • 执行后可以看到NameServer启动成功的信息。
  3. 启动Broker。
    • 打开命令行窗口,切换到D:\rocketmq-4.7.0\bin目录,输入mqbroker -n 127.0.0.1:9876命令启动Broker。
    • 执行后可以看到Broker启动成功的信息。
  4. 验证RocketMQ是否启动成功。
    • 通过浏览器打开http://localhost:9876,可以看到NameServer的管理界面。
    • NameServer管理界面会显示当前NameServer的信息,以及Broker的连接状态。

至此,RocketMQ已经成功安装并启动。

在RocketMQ的配置文件broker.properties中,可以设置一些关键参数:

brokerName=broker-a
brokerId=0
namesrvAddr=127.0.0.1:9876
RocketMQ基本概念与架构
Topic与Tag

Topic

在RocketMQ中,Topic是消息的分类标识,所有的消息都会归属于某个Topic。生产者发送消息时会指定Topic,消费者在消费消息时也按照Topic来订阅消息。一个Topic可以理解为一个消息队列,每个Topic下可以有多个Message Queue。

Tag

Tag是消息的标签,用来进一步精细化消息的分类。一个Topic下可以有多个Tag,Tag的作用类似于Topic,但是更加细化。生产者在发送消息时可以指定Tag,消费者在消费消息时也可以根据Tag来过滤和订阅消息。

示例代码

创建一个Topic为testTopic,Tag为testTag的消息。

import org.apache.rocketmq.client.producer.DefaultMQProducer;
import org.apache.rocketmq.client.producer.MessageQueueSelector;
import org.apache.rocketmq.client.producer.SendResult;
import org.apache.rocketmq.client.producer.selector.AnyMessageQueueSelector;
import org.apache.rocketmq.common.message.Message;
import org.apache.rocketmq.common.message.MessageQueue;

public class TopicTagProducer {
    public static void main(String[] args) throws Exception {
        // 创建生产者
        DefaultMQProducer producer = new DefaultMQProducer("ProducerGroupName");
        // 设置NameServer地址
        producer.setNamesrvAddr("127.0.0.1:9876");
        // 启动生产者
        producer.start();

        // 创建消息
        Message msg = new Message(
                "testTopic", // Topic
                "testTag", // Tag
                "Hello RocketMQ".getBytes() // 消息内容
        );

        // 发送消息
        SendResult sendResult = producer.send(msg);
        System.out.println("发送结果: " + sendResult);

        // 关闭生产者
        producer.shutdown();
    }
}
Producer与Consumer

Producer

Producer是发送消息的一方,负责生成并发送消息到RocketMQ的Topic中。在RocketMQ中,一个Producer实例可以发送消息到多个Topic中,每个Topic可以有多个Tag,这些信息都会通过Producer配置进行设置。

Consumer

Consumer是消费消息的一方,负责从RocketMQ的Topic中接收并处理消息。在RocketMQ中,一个Consumer实例可以订阅多个Topic中的消息,每个Topic可以有多个Tag,这些信息同样通过Consumer配置进行设置。

示例代码

创建一个testTopic Topic的消息消费者。

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeOrderedSuccess;
import org.apache.rocketmq.client.consumer.listener.MessageListenerOrderly;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;

public class TopicConsumer {
    public static void main(String[] args) throws Exception {
        // 创建消费者
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("ConsumerGroupName");
        // 设置NameServer地址
        consumer.setNamesrvAddr("127.0.0.1:9876");
        // 设置Consumer消费的Topic名称
        consumer.subscribe("testTopic", "*");
        // 设置拉取消息的位置
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);
        // 设置消息监听器
        consumer.setMessageListener(new MessageListenerOrderly() {
            @Override
            public ConsumeOrderedResult consumeMessage(List<MessageExt> msgs, MessageQueue messageQueue) {
                for (MessageExt msg : msgs) {
                    System.out.println("消费到消息: " + new String(msg.getBody()));
                }
                return ConsumeOrderedResult.SUCCESS;
            }
        });
        // 启动消费者
        consumer.start();
    }
}
Message与Message Queue

Message

Message是RocketMQ中基本的消息单元,包含消息体(Body)、消息头(Headers)等信息。消息体是消息的主要内容,消息头可以包含一些扩展信息,比如Tag等。

Message Queue

Message Queue是RocketMQ中消息的传输通道,一个Topic可以包含多个Message Queue,每个Message Queue都有一个唯一的ID,用于负载均衡和消息的顺序消费。

RocketMQ消息发送与接收
创建Producer实例

创建一个RocketMQ消息生产者实例,配置NameServer地址和生产者组名。

import org.apache.rocketmq.client.producer.DefaultMQProducer;

public class ProducerExample {
    public static void main(String[] args) throws Exception {
        // 创建生产者实例
        DefaultMQProducer producer = new DefaultMQProducer("ProducerGroup");
        // 设置NameServer地址
        producer.setNamesrvAddr("127.0.0.1:9876");
        // 启动生产者
        producer.start();
    }
}
发送同步消息

使用同步模式发送消息,发送消息后会等待消息发送结果返回。

import org.apache.rocketmq.client.producer.DefaultMQProducer;
import org.apache.rocketmq.common.message.Message;
import org.apache.rocketmq.common.message.SendResult;
import org.apache.rocketmq.remoting.common.RemotingHelper;

public class SyncProducerExample {
    public static void main(String[] args) throws Exception {
        // 创建生产者实例
        DefaultMQProducer producer = new DefaultMQProducer("ProducerGroup");
        // 设置NameServer地址
        producer.setNamesrvAddr("127.0.0.1:9876");
        // 启动生产者
        producer.start();

        // 创建消息
        Message msg = new Message(
                "TestTopic", // Topic
                "TagA", // Tag
                ("Hello RocketMQ").getBytes(RemotingHelper.DEFAULT_CHARSET) // 消息内容
        );

        // 发送消息并等待发送结果
        SendResult sendResult = producer.send(msg);
        System.out.println("发送结果: " + sendResult);

        // 关闭生产者
        producer.shutdown();
    }
}
发送异步消息

使用异步模式发送消息,发送消息后通过回调函数接收消息发送结果。

import org.apache.rocketmq.client.producer.DefaultMQProducer;
import org.apache.rocketmq.client.producer.SendCallback;
import org.apache.rocketmq.client.producer.SendResult;
import org.apache.rocketmq.common.message.Message;

public class AsyncProducerExample {
    public static void main(String[] args) throws Exception {
        // 创建生产者实例
        DefaultMQProducer producer = new DefaultMQProducer("ProducerGroup");
        // 设置NameServer地址
        producer.setNamesrvAddr("127.0.0.1:9876");
        // 启动生产者
        producer.start();

        // 创建消息
        Message msg = new Message(
                "TestTopic", // Topic
                "TagA", // Tag
                ("Hello RocketMQ").getBytes() // 消息内容
        );

        // 发送消息并设置回调函数
        producer.send(msg, new SendCallback() {
            @Override
            public void onSuccess(SendResult sendResult) {
                System.out.println("消息发送成功: " + sendResult);
            }

            @Override
            public void onException(Throwable e) {
                System.out.println("消息发送异常: " + e.getMessage());
            }
        });

        // 关闭生产者
        producer.shutdown();
    }
}
创建Consumer实例

创建一个RocketMQ消息消费者实例,配置NameServer地址和消费者组名。

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;

public class ConsumerExample {
    public static void main(String[] args) throws Exception {
        // 创建消费者实例
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("ConsumerGroup");
        // 设置NameServer地址
        consumer.setNamesrvAddr("127.0.0.1:9876");
        // 设置消费者消费的Topic名称
        consumer.subscribe("TestTopic", "*");
        // 设置拉取消息的位置
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);
        // 启动消费者
        consumer.start();
    }
}
消息接收与处理

在消费者中添加消息监听器来接收并处理消息。

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeOrderedSuccess;
import org.apache.rocketmq.client.consumer.listener.MessageListenerOrderly;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;

public class ConsumerMessageListenerExample {
    public static void main(String[] args) throws Exception {
        // 创建消费者实例
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("ConsumerGroup");
        // 设置NameServer地址
        consumer.setNamesrvAddr("127.0.0.1:9876");
        // 设置消费者消费的Topic名称
        consumer.subscribe("TestTopic", "*");
        // 设置拉取消息的位置
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);

        // 设置消息监听器
        consumer.setMessageListener(new MessageListenerOrderly() {
            @Override
            public ConsumeOrderedResult consumeMessage(List<MessageExt> msgs, MessageQueue messageQueue) {
                for (MessageExt msg : msgs) {
                    System.out.println("接收到消息: " + new String(msg.getBody()));
                }
                return ConsumeOrderedResult.SUCCESS;
            }
        });

        // 启动消费者
        consumer.start();
    }
}
RocketMQ消息消费模型
广播模式

广播模式下,消息会被推送到同一个消费者组内的所有消费者实例,每个消费者都会收到相同的消息。

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeOrderedSuccess;
import org.apache.rocketmq.client.consumer.listener.MessageListenerOrderly;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;

public class BroadcastConsumerExample {
    public static void main(String[] args) throws Exception {
        // 创建消费者实例
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("ConsumerGroup");
        // 设置NameServer地址
        consumer.setNamesrvAddr("127.0.0.1:9876");
        // 设置消费者消费的Topic名称
        consumer.subscribe("TestTopic", "*");
        // 设置拉取消息的位置
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);

        // 设置消息监听器
        consumer.setMessageListener(new MessageListenerOrderly() {
            @Override
            public ConsumeOrderedResult consumeMessage(List<MessageExt> msgs, MessageQueue messageQueue) {
                for (MessageExt msg : msgs) {
                    System.out.println("广播模式接收到消息: " + new String(msg.getBody()));
                }
                return ConsumeOrderedResult.SUCCESS;
            }
        });

        // 启动消费者
        consumer.start();
    }
}
集群模式

集群模式下,消息只会被推送到消费者组中的一个消费者实例,其他消费者不会收到相同的消息。

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeOrderedSuccess;
import org.apache.rocketmq.client.consumer.listener.MessageListenerOrderly;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;

public class ClusterConsumerExample {
    public static void main(String[] args) throws Exception {
        // 创建消费者实例
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("ConsumerGroup");
        // 设置NameServer地址
        consumer.setNamesrvAddr("127.0.0.1:9876");
        // 设置消费者消费的Topic名称
        consumer.subscribe("TestTopic", "*");
        // 设置拉取消息的位置
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);

        // 设置消息监听器
        consumer.setMessageListener(new MessageListenerOrderly() {
            @Override
            public ConsumeOrderedResult consumeMessage(List<MessageExt> msgs, MessageQueue messageQueue) {
                for (MessageExt msg : msgs) {
                    System.out.println("集群模式接收到消息: " + new String(msg.getBody()));
                }
                return ConsumeOrderedResult.SUCCESS;
            }
        });

        // 启动消费者
        consumer.start();
    }
}
实际项目中的应用案例

在实际项目中,广播模式适用于所有消费者都需要处理相同数据的场景,例如配置更新、系统通知等。集群模式适用于高并发场景,每个消费者可以处理一部分消息,提高系统的吞吐量。

例如,在一个订单系统中,可以使用集群模式来处理订单消息,每个消费者实例负责处理一部分订单,从而提高订单处理的效率。

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeOrderedSuccess;
import org.apache.rocketmq.client.consumer.listener.MessageListenerOrderly;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;

public class OrderSystemConsumerExample {
    public static void main(String[] args) throws Exception {
        // 创建消费者实例
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("OrderSystemConsumerGroup");
        // 设置NameServer地址
        consumer.setNamesrvAddr("127.0.0.1:9876");
        // 设置消费者消费的Topic名称
        consumer.subscribe("OrderTopic", "*");
        // 设置拉取消息的位置
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);

        // 设置消息监听器
        consumer.setMessageListener(new MessageListenerOrderly() {
            @Override
            public ConsumeOrderedResult consumeMessage(List<MessageExt> msgs, MessageQueue messageQueue) {
                for (MessageExt msg : msgs) {
                    System.out.println("订单系统消费消息: " + new String(msg.getBody()));
                }
                return ConsumeOrderedResult.SUCCESS;
            }
        });

        // 启动消费者
        consumer.start();
    }
}
RocketMQ消息过滤与路由
使用Tag进行消息过滤

通过Tag来过滤消息,消费者可以根据Tag来订阅消息。

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeOrderedSuccess;
import org.apache.rocketmq.client.consumer.listener.MessageListenerOrderly;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;

public class TagFilterConsumerExample {
    public static void main(String[] args) throws Exception {
        // 创建消费者实例
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("ConsumerGroup");
        // 设置NameServer地址
        consumer.setNamesrvAddr("127.0.0.1:9876");
        // 设置消费者消费的Topic名称
        consumer.subscribe("TestTopic", "TagA");
        // 设置拉取消息的位置
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);

        // 设置消息监听器
        consumer.setMessageListener(new MessageListenerOrderly() {
            @Override
            public ConsumeOrderedResult consumeMessage(List<MessageExt> msgs, MessageQueue messageQueue) {
                for (MessageExt msg : msgs) {
                    System.out.println("Tag A 接收到消息: " + new String(msg.getBody()));
                }
                return ConsumeOrderedResult.SUCCESS;
            }
        });

        // 启动消费者
        consumer.start();
    }
}
使用SQL92进行复杂查询

RocketMQ支持SQL92查询来实现复杂的过滤条件。

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeOrderedSuccess;
import org.apache.rocketmq.client.consumer.listener.MessageListenerOrderly;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;

public class SqlFilterConsumerExample {
    public static void main(String[] args) throws Exception {
        // 创建消费者实例
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("ConsumerGroup");
        // 设置NameServer地址
        consumer.setNamesrvAddr("127.0.0.1:9876");
        // 设置消费者消费的Topic名称
        consumer.subscribe("TestTopic", "select * from TestTopic where Tag='TagB'");
        // 设置拉取消息的位置
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);

        // 设置消息监听器
        consumer.setMessageListener(new MessageListenerOrderly() {
            @Override
            public ConsumeOrderedResult consumeMessage(List<MessageExt> msgs, MessageQueue messageQueue) {
                for (MessageExt msg : msgs) {
                    System.out.println("SQL 查询接收到消息: " + new String(msg.getBody()));
                }
                return ConsumeOrderedResult.SUCCESS;
            }
        });

        // 启动消费者
        consumer.start();
    }
}
消息路由与负载均衡

RocketMQ通过Broker来实现消息路由和负载均衡,Broker可以配置多个Message Queue来实现消息的均衡分布。当生产者发送消息时,Broker会根据消息的Topic和Tag来决定将消息分配到哪个Message Queue。

RocketMQ项目实战与最佳实践
RocketMQ在分布式系统中的应用

RocketMQ适用于大规模分布式系统的消息传递,能够很好地支持异步解耦、流量削峰、日志收集、监控等场景。在实际项目中,可以使用RocketMQ来实现订单处理、通知同步、事件驱动等功能。

例如,一个电商系统可以使用RocketMQ来处理订单,当用户下单后,订单消息会被发送到RocketMQ,然后由不同的消费者实例来处理订单支付、物流、订单状态更新等功能。

高可用与容错机制

RocketMQ通过集群部署和消息重试机制来实现高可用和容错。当某个Broker失效时,其他Broker可以继续提供服务,保障系统的可用性。RocketMQ还支持消息重试机制,当消费者消费消息失败时,可以自动重试消费。

示例代码

配置RocketMQ的消息重试次数。

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeOrderedSuccess;
import org.apache.rocketmq.client.consumer.listener.MessageListenerOrderly;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;

public class RetryConsumerExample {
    public static void main(String[] args) throws Exception {
        // 创建消费者实例
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("ConsumerGroup");
        // 设置NameServer地址
        consumer.setNamesrvAddr("127.0.0.1:9876");
        // 设置消费者消费的Topic名称
        consumer.subscribe("TestTopic", "*");
        // 设置拉取消息的位置
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);

        // 设置消息监听器
        consumer.setMessageListener(new MessageListenerOrderly() {
            @Override
            public ConsumeOrderedResult consumeMessage(List<MessageExt> msgs, MessageQueue messageQueue) {
                try {
                    for (MessageExt msg : msgs) {
                        System.out.println("接收到消息: " + new String(msg.getBody()));
                        // 模拟消息处理失败
                        throw new RuntimeException("模拟消息处理失败");
                    }
                } catch (Exception e) {
                    // 消息处理失败,返回失败结果
                    System.out.println("消息处理失败,将进行重试: " + e.getMessage());
                    return ConsumeOrderlyResult.FAILURE;
                }
                return ConsumeOrderedResult.SUCCESS;
            }
        });

        // 启动消费者
        consumer.start();
    }
}
性能调优与监控

RocketMQ提供多种配置项来实现性能调优,例如设置消息堆积阈值、调整消息缓存大小等。RocketMQ还提供了监控功能,可以实时查看消息的发送、消费情况,帮助及时发现和解决问题。

示例代码

设置RocketMQ消息堆积阈值。

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeOrderedSuccess;
import org.apache.rocketmq.client.consumer.listener.MessageListenerOrderly;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;

public class PerformanceTuningConsumerExample {
    public static void main(String[] args) throws Exception {
        // 创建消费者实例
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("ConsumerGroup");
        // 设置NameServer地址
        consumer.setNamesrvAddr("127.0.0.1:9876");
        // 设置消费者消费的Topic名称
        consumer.subscribe("TestTopic", "*");
        // 设置拉取消息的位置
        consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);

        // 设置消费者的消息堆积阈值
        consumer.setMessageListener(new MessageListenerOrderly() {
            @Override
            public ConsumeOrderedResult consumeMessage(List<MessageExt> msgs, MessageQueue messageQueue) {
                for (MessageExt msg : msgs) {
                    System.out.println("接收到消息: " + new String(msg.getBody()));
                }
                return ConsumeOrderedResult.SUCCESS;
            }
        });

        // 启动消费者
        consumer.start();
    }
}

性能调优策略

  • 调整Broker配置,例如设置消息堆积阈值、消息缓存大小等。
  • 配置生产者和消费者的线程池大小,合理分配资源。
  • 使用集群模式提高吞吐量。
  • 通过监控来实时查看消息的发送和消费情况,及时发现问题。
  • 使用消息重试机制来提高系统的可靠性。
  • 通过消息过滤和路由来减少不必要的消息处理。

通过以上策略,可以有效地提升RocketMQ的性能和稳定性。

0人推荐
随时随地看视频
慕课网APP