【RocketMQ】4、Windows10单机环境部署



文章目录

  • 【RocketMQ】4、Windows10单机环境部署
  • 一、RocketMQ下载
  • 二、环境搭建
  • 三、启动RocketMQ
  • 四、图形管理控制台Console
  • 1、下载
  • 2、更改配置
  • 3、Maven打包
  • 4、启动
  • 四、测试
  • 1、按前面步骤启动NameServer、Broker、Console
  • 2、代码测试



一、RocketMQ下载

官网下载地址:https://rocketmq.apache.org/dowloading/releases/

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_maven

下载解压后文件夹截图

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_apache_02

二、环境搭建

需提前配好Java环境

  • 变量名:ROCKETMQ_HOME 变量值:D:\Envs\RocketMQ\rocketmq-all-4.9.4-bin-release
  • rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_rocketmq_03


三、启动RocketMQ

进入到bin目录下

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_java-rocketmq_04

  • 启动NameServer
    双击mqnamesrv.cmd
  • rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_apache_05

  • 启动Broker
    修改conf\broker.conf配置文件,添加Name Server地址:namesrvAddr = 127.0.0.1:9876
  • rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_java-rocketmq_06

  • start bin\mqbroker.cmd -c conf\broker.conf 启动Broker
  • rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_maven_07

踩坑:没有添加name server地址控制台启动Broker时,控制台没有Name Server地址显示

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_maven_08


且会导致后面生产者发送消息失败,显示Exception in thread "main" org.apache.rocketmq.client.exception.MQClientException: No route info of this topic: TopicTest

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_apache_09

四、图形管理控制台Console

1、下载

Console项目在develop分支下
地址:https://github.com/apache/rocketmq-externals/tree/develop Clone下来后,用idea打开

2、更改配置

修改console项目中的application.properties文件

  • Console端口号server.port=9999
  • NameServer地址rocketmq.config.namesrvAddr=0.0.0.0:9876
  • 数据存放路径rocketmq.config.dataPath=D:/Envs/RocketMQ/rocketmq-console
  • rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_java_10


踩坑rocketmq.config.dataPath中的路径分隔符为反斜杠“/”,否则后面执行包时会报错找不到文件夹。

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_java-rocketmq_11

3、Maven打包

进入console目录后用maven打包

命令:mvn clean package ‘-Dmaven.test.skip=true’

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_maven_12

踩坑:提示Unknown lifecycle phase ".test.skip=true". You must specify a valid lifecycle phase or a goal in the format

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_java-rocketmq_13

原因: IntelliJ IDEA 的终端默认使用 PowerShell 来运行命令,而在 PowerShell 下,参数 -Dmaven.test.skip=true 没有被正确地识别。

解决方法:

  • 在此参数外加单引号即可,即:mvn package '-Dmaven.test.skip=true'
  • 也可以选择将 IntelliJ IDEA 的终端设置成 CMD 模式(Command Prompt)

踩坑:提示Could not find artifact org.apache.rocketmq:rocketmq-tools:jar:4.4.0-SNAPSHOT

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_rocketmq_14


解决方法:

  • 将pom文件中的<rocketmq.version>4.4.0-SNAPSHOT</rocketmq.version> 修改为 <rocketmq.version>4.4.0</rocketmq.version>

4、启动

进入target文件夹,控制台命令java -jar .\rocketmq-console-ng-1.0.0.jar

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_maven_15

浏览器输入刚刚设置的Console地址和端口127.0.0.1:9999,控制台启动成功。

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_java_16

四、测试

1、按前面步骤启动NameServer、Broker、Console

2、代码测试

测试代码使用官方的demo,链接:https://github.com/apache/rocketmq/blob/master/docs/cn/RocketMQ_Example.md

  • Maven依赖
<dependency>
    <groupId>org.apache.rocketmq</groupId>
    <artifactId>rocketmq-client</artifactId>
    <version>4.9.1</version>
</dependency>
  • 先运行生产者(同步消息)
public class SyncProducer {
    public static void main(String[] args) throws Exception {
        // 实例化消息生产者Producer
        DefaultMQProducer producer = new DefaultMQProducer("pg1");
        // 设置NameServer的地址
        producer.setNamesrvAddr("localhost:9876");
        // 启动Producer实例
        producer.start();
        for (int i = 0; i < 100; i++) {
            // 创建消息,并指定Topic,Tag和消息体
            Message msg = new Message("TopicTest" /* Topic */,
                    "TagA" /* Tag */,
                    ("Hello RocketMQ " + i).getBytes(RemotingHelper.DEFAULT_CHARSET) /* Message body */
            );
            // 发送消息到一个Broker
            SendResult sendResult = producer.send(msg);
            // 通过sendResult返回消息是否成功送达
            System.out.printf("%s%n", sendResult);
        }
        // 如果不再发送消息,关闭Producer实例。
        producer.shutdown();
    }
}

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_apache_17

  • 后运行消费者
public class Consumer {
    public static void main(String[] args) throws InterruptedException, MQClientException {
        // 实例化消费者
        DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("cg1");
        // 设置NameServer的地址
        consumer.setNamesrvAddr("localhost:9876");
        // 订阅一个或者多个Topic,以及Tag来过滤需要消费的消息
        consumer.subscribe("TopicTest", "*");
        // 注册回调实现类来处理从broker拉取回来的消息
        consumer.registerMessageListener(new MessageListenerConcurrently() {
            @Override
            public ConsumeConcurrentlyStatus consumeMessage(List<MessageExt> msgs, ConsumeConcurrentlyContext context) {
                System.out.printf("%s Receive New Messages: %s %n", Thread.currentThread().getName(), msgs);
                // 标记该消息已经被成功消费
                return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;
            }
        });
        // 启动消费者实例
        consumer.start();
        System.out.printf("Consumer Started.%n");
    }
}

rocketmq RocketMQTemplate 配置多个producer rocketmq配置详解_rocketmq_18