本地编译rocketmq源码

源码下载

RocketMq下载

运行

这是rocketmq源码大致的业务分层,本地调试主要是启动nameserver和broker,其他的发送和接收的实现代码可直接使用example包中的官方例子,也可以自己编码代码实现。

  1. 启动namesrv包下的启动类,NamesrvStartup
java 复制代码
Connected to the target VM, address: '127.0.0.1:9351', transport: 'socket'
Please set the ROCKETMQ_HOME variable in your environment to match the location of the RocketMQ installation
Disconnected from the target VM, address: '127.0.0.1:9351', transport: 'socket'

初次启动的时候它会提示这个异常信息,提示你没有配置ROCKETMQ_HOME变量。

从字面上理解其实就是rocketmq源码在我们磁盘上的一个路径而已。

只需要在启动配置里面添加上如上配置即可,ROCKETMQ_HOME=你的rocketmq磁盘路径,下面的broker模块启动的时候也要配置上去。

java 复制代码
The Name Server boot success. serializeType=JSON, address 0.0.0.0:9876

看到这个就是启动成功了。

  1. 启动broker,运行的是BrokerStartup
java 复制代码
xxx boot success. serializeType=JSON

看到这个就是启动成功了。

  1. 运行producer和consumer
    这里运行的不是源码包中的example样例,而是自己实现的producer和consumer。

producer如下:

java 复制代码
public static void main(String[] args) {
        String nameServer = "localhost:9876";
        DefaultMQProducer defaultMQProducer = new DefaultMQProducer();
        defaultMQProducer.setNamesrvAddr(nameServer);
        defaultMQProducer.setProducerGroup("test-group");
        try {
            defaultMQProducer.start();
            String message = "hello";
            SendResult send = defaultMQProducer.send(new Message("test", message.getBytes()));
            System.out.println("send hello over");
            System.out.println(send.getSendStatus());
            defaultMQProducer.shutdown();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

consumer如下:

java 复制代码
public static void main(String[] args) {
        String nameServer = "localhost:9876";
        DefaultMQPushConsumer defaultMQPushConsumer = new DefaultMQPushConsumer();
        defaultMQPushConsumer.setNamesrvAddr(nameServer);
        defaultMQPushConsumer.setConsumerGroup("test-consumer-group");
        try {
            defaultMQPushConsumer.subscribe("test", (String) null);
            defaultMQPushConsumer.registerMessageListener(new MessageListenerOrderly() {
                @Override
                public ConsumeOrderlyStatus consumeMessage(List<MessageExt> msgs, ConsumeOrderlyContext context) {
                    for (MessageExt msg : msgs) {
                        String s = new String(msg.getBody());
                        System.out.println(s);
                    }
                    return ConsumeOrderlyStatus.SUCCESS;
                }
            });
            defaultMQPushConsumer.start();
            TimeUnit.SECONDS.sleep(10);
            defaultMQPushConsumer.shutdown();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

运行producer提示如下异常信息:

java 复制代码
**org.apache.rocketmq.client.exception.MQClientException: No route info of this topic: test**
See https://rocketmq.apache.org/docs/bestPractice/06FAQ for further details.
	at org.apache.rocketmq.client.impl.producer.DefaultMQProducerImpl.sendDefaultImpl(DefaultMQProducerImpl.java:718)
	at org.apache.rocketmq.client.impl.producer.DefaultMQProducerImpl.send(DefaultMQProducerImpl.java:1400)
	at org.apache.rocketmq.client.impl.producer.DefaultMQProducerImpl.send(DefaultMQProducerImpl.java:1342)
	at org.apache.rocketmq.client.producer.DefaultMQProducer.send(DefaultMQProducer.java:351)

从错误信息中可以看到,它是因为没有路由信息,其实说白了就是没有创建这个topic。

在BrokerStartup类中,如上图位置,添加nameserver的地址即可。

  1. 输出结果

    这就是consumer消费的消息。

本地rocketmq可以正常启动以后,就可以按照rocketmq的业务逻辑进行debug调试了,便于我们更好的理解rocketmq的原理。

相关推荐
周杰伦_Jay1 天前
【RocketMQ全面解析】架构原理、消费类型、性能优化、环境搭建
性能优化·架构·rocketmq
默 语2 天前
消息中间件选型的艺术:如何在RocketMQ、Kafka、RabbitMQ中做出正确决策
java·架构·kafka·消息队列·rabbitmq·rocketmq·技术选型
心之伊始2 天前
RocketMQ 与 Kafka 架构与实现详解对比
架构·kafka·rocketmq
柳贯一(逆流河版)3 天前
RocketMQ 实战:马拉松系统异步化与延时任务落地(含死信队列处理)
rocketmq
koping_wu5 天前
【RocketMQ】架构原理、消息丢失、重复消费、顺序消费、事务消息
架构·rocketmq·java-rocketmq
Savvy..5 天前
消息队列MQ
kafka·消息队列·rabbitmq·rocketmq·mq
235165 天前
【MQ】RabbitMQ:架构、工作模式、高可用与流程解析
java·分布式·架构·kafka·rabbitmq·rocketmq·java-rabbitmq
会跑的葫芦怪6 天前
RocketMQ 与 RabbitMQ 全面对比:架构、性能与适用场景解析
架构·rabbitmq·rocketmq
失散136 天前
分布式专题——39 RocketMQ客户端编程模型
java·分布式·架构·rocketmq
JAVA学习通6 天前
发布自己的 jar 包到 Maven 中央仓库 ( mvnrepository.com )
人工智能·docker·自然语言处理·容器·rocketmq