RocketMQ系列-搭建Namesrv源码调试环境

在学习任何一个技术框架的时候,我们通常都是先了解是什么,有什么作用、解决什么问题、设计亮点和设计思想是什么;当然对于技术学习上来说,这只是纸上谈兵,一开始比较基础的学习,当我们想要深入的时候,我们必不可少的就是希望能够去调试源码,能够在本地运行一下这个技术框架,能够断点调试一下这个框架最核心的功能或者看一下内部的数据结构。所以我们学习一个技术框架,特别核心的一点就是,要在本地搭建我们的源码调试环境。

笔者在这里,就把RocketMQ的整个源码调试环境搭建的过程给梳理出来,不过因为笔者的开发环境是Windows的,所以以下所有内容都是基于Windows环境实践得出来的。

PS:笔者在这里说一下,可能对于不了解RocketMQ或者说是零基础的读者来说,会有一些很陌生的词汇,例如Namesrv,Broker之类的,也不用怕,因为这个RocketMQ系列的诞生,正是因为笔者完完全全体验到了学习RocketMQ的痛苦,不想对RocketMQ感兴趣想要深入研究的读者也体验一遍,所以才总结自己这次学习RocketMQ的方式,让读者能够完全从使用角度去了解,研究RocketMQ的功能以及深入源码,而不是一个模块一个模块的单体化了解。

Namesrv源码调试环境搭建

导入项目到IDEA

因为笔者用的IDEA开发工具,所以以下的教程演示都是基于IDEA的。

  • 克隆项目到本地

https://github.com/apache/rocketmq

读者需要先将RocketMQ的源码给下载到本地来。

在这里,笔者给各位读者一个建议,可以先将RocketMQ的源码从GitHub导入到码云,然后再克隆到本地来,最好创建一个新的分支来进行源码学习和写一定的注释

  • 导入项目到IDEA

按照maven的方式open RocketMQ目录,因为笔者已经open过了,所以不会出现maven的提示,如果读者的出现了,点击trust project即可,然后就等待下载对应的依赖即可

创建所需目录

我们使用任何一个中间件,都知道在部署启动的时候,肯定是会有存放配置文件的目录,还会有保存中间件本身产生对应日志和数据的目录,我们这里就是需要创建这样的目录。

  • 配置文件目录-conf

在RocketMQ源码根目录下创建存放配置文件的目录-conf

  • 创建数据目录-data

在RocketMQ源码根目录下创建存放RocketMQ本身存放数据的目录-data

  • 创建日志目录-logs

在RocketMQ源码根目录下创建存放RocketMQ运行日志的目录-logs

环境配置

  • 将Namesrv的日志配置拷贝到我们上面创建的conf目录下

读者可能会疑惑,我怎么知道Namesrv的日志配置是怎么样的,这些问题RocketMQ都已经给我们想好了,在RocketMQ源码目录下,有一个distribution的目录,下面有不同模式部署RocketMQ对应的配置文件,目前我们本地跑,暂时只需要使用外面最基础的配置文件就可

  • 配置环境变量

我们需要配置对应的环境变量,让RocketMQ启动的时候,把我们当前的源码目录作为根目录,这样它才能找到运行所需的配置文件在哪

ROCKETMQ_HOME=E:\study\source_code_learn\rocketmq

  • 修改${user.home}属性

读者可以打开刚才准备好的日志文件看一下,发现里面会有一堆${user.home}

我们想把RocketMQ运行产生的日志指定放在我们之前准备好的logs目录下的话,放任不管肯定是不行,当然读者也可以选择直接将${user.home}直接全量替换成我们日志目录的绝对路径,不过在这里,笔者喜欢用另一种方式,通过增加一句代码的方式来实现。

我们打开Namesrv的启动类,也就是org.apache.rocketmq.namesrv.NamesrvStartup。在里面加上一句代码

public static NamesrvController main0(String[] args) {

        try {
// 添加此行代码指定user.home
System.setProperty("user.home", "E:/study/source_code_learn/rocketmq");
NamesrvController controller = createNamesrvController(args);
start(controller);
String tip = "The Name Server boot success. serializeType=" + RemotingCommand.getSerializeTypeConfigInThisServer();
log.info(tip);
System.out.printf("%s%n", tip);
return controller;
} catch (Throwable e) {
e.printStackTrace();
System.exit(-1);
} return null;
}

启动Namesrv

到了最关键的时候,直接启动Namesrv

点击启动按钮,看到如下输出,还有如果有对应日志文件产生,那就是成功了

总结

通过上面一系列的操作,我们终于把我们的Namesrv给启动起来了,这样子我们就能够在我们本地去调试Namesrv启动的整个过程,可以看一下都进行了什么操作,内部使用了什么数据结构,保存了什么元数据。还是那句,想要深入研究任何一个技术框架,在自己本地搭建一个源码调试环境是必不可少的。

题外话

也许有不少读者会觉得这文章实在是太过于简单了,但是笔者是打算总结自己这次在学习RocketMQ当中遇到的所有痛点,然后按照一个使用者,结合深入学习的角度去一步步深入,才会打算将自己的整个学习过程给整理成一个系列,最后输出成文章,一是希望将自己的所学进行沉淀,二也是希望广大读者能够减少在学习RocketMQ当中的弯路

RocketMQ系列-搭建Namesrv源码调试环境的更多相关文章

  1. [原创]在Windows和Linux中搭建PostgreSQL源码调试环境

    张文升http://ode.cnblogs.comEmail:wensheng.zhang#foxmail.com 配图太多,完整pdf下载请点这里 本文使用Xming.Putty和VMWare几款工 ...

  2. 如何搭建自己的SpringBoot源码调试环境?--SpringBoot源码(一)

    1 前言 这是SpringBoot2.1源码分析专题的第一篇文章,主要讲如何来搭建我们的源码阅读调试环境.如果有经验的小伙伴们可以略过此篇文章. 2 环境安装要求 IntelliJ IDEA JDK1 ...

  3. 【深入浅出 Yarn 架构与实现】1-2 搭建 Hadoop 源码阅读环境

    本文将介绍如何使用 idea 搭建 Hadoop 源码阅读环境.(默认已安装好 Java.Maven 环境) 一.搭建源码阅读环境 一)idea 导入 hadoop 工程 从 github 上拉取代码 ...

  4. 在IDEA中搭建Java源码学习环境并上传到GitHub上

    打开IDEA新建一个项目 创建一个最简单的Java项目即可 在项目命名填写该项目的名称,我这里写的项目名为Java_Source_Study 点击Finished,然后在项目的src目录下新建源码文件 ...

  5. 利用IDEA搭建JDK源码阅读环境

    利用IDEA搭建JDK源码阅读环境 首先新建一个java基础项目 基础目录 source 源码 test 测试源码和入口 准备JDK源码 下图框起来的路径就是jdk的储存位置 打开jdk目录,找到sr ...

  6. win7+idea+maven搭建spark源码阅读环境

    1.参考. 利用IDEA工具编译Spark源码(1.60~2.20) https://blog.csdn.net/He11o_Liu/article/details/78739699 Maven编译打 ...

  7. 搭建 Spring 源码阅读环境

    前言 有一个Spring源码阅读环境是学习Spring的基础.笔者借鉴了网上很多搭建环境的方法,也尝试了很多,接下来总结两种个人认为比较简便实用的方法.读者可根据自己的需要自行选择. 方法一:搭建基础 ...

  8. Mac搭建Hadoop源码阅读环境

    1.本次Hadoop源码阅读环境使用的阅读工具是idea,Hadoop版本是2.7.3.需要安装的工具包括idea.jdk.maven.protobuf等 2.jdk,使用的版本是1.8版,在jdk官 ...

  9. 深入理解Tomcat系列之二:源码调试环境搭建(转)

    前言 最近对Tomcat的源码比较感兴趣,于是折腾了一番.要调试源码首先需要搭建环境,由于参考了几篇帖子发现都不怎么靠谱,最后还是折腾出来了,然而却花了足足一天的时间去搭建这个环境.发现都不是帖子的问 ...

  10. 15分钟搭建RocketMQ源码调试环境

    下载源码 下载源码,github页面选择(rocketmq-all-4.7.1)版本压缩包,https://github.com/apache/rocketmq/tags 导入IDEA 1. 使用ID ...

随机推荐

  1. golang 实现笛卡尔积(泛型)

    背景 input: [[a,b],[c],[d,e]] output: [[a,c,d],[a,c,e],[b,c,d],[b,c,e]] 思路:分治 预处理第一项:[a,b] -> [[a], ...

  2. 2022-9-5 JavaSE note

    Java SE 1.IDEA基本操作 psvm + 回车 : main() 方法声明 sout + 回车 : = System.out.println(); Ctrl + D : 把当前行复制到下一行 ...

  3. .NET WebAPI 自定义 NullableConverter 解决请求入参 “”空字符触发转换异常问题

    最近在项目中启用了Nullable 可为空的类型,这个特性确实很好用,在 WebAPI 的入参上可以直接采用 ? 来标记一个字段是否允许为空,但是使用过程中遇到了如下一个问题,比如创建部门接口 我们定 ...

  4. Beats:运用 Filebeat 来对微服务 API 进行分析

    文章转载自:https://elasticstack.blog.csdn.net/article/details/118145104 需要学习的是httpjson请求的写法 使用 Filebeat 的 ...

  5. 使用kuboard界面管理k8s集群时使用ConfigMap挂载挂载到pod容器中,映射成一个文件夹

    将 ConfigMap 作为一个数据卷(在挂载时不指定数据卷内子路径,需要指定ConfigMap的子路径)挂载到容器,此时 ConfigMap 将映射成一个文件夹,每一个 KEY 是文件夹下的文件名, ...

  6. WPF绘制圆形调色盘

    本文使用writeableBitmap类和HSB.RGB模式来绘制圆形的调色盘. 开源项目地址:https://github.com/ZhiminWei/Palette RGB为可见光波段三个颜色通道 ...

  7. Petrozavodsk Winter Training Camp 2016: Moscow SU Trinity Contest

    题目列表 A.ABBA E.Elvis Presley G. Biological Software Utilities J. Burnished Security Updates A.ABBA 题意 ...

  8. 从零开始学Graph Database:什么是图

    摘要:本文从零开始引导与大家一起学习图知识.希望大家可以通过本教程学习如何使用图数据库与图计算引擎.本篇将以华为云图引擎服务来辅助大家学习如何使用图数据库与图计算引擎. 本文分享自华为云社区<从 ...

  9. Python编程之多进程(multiprocessing)详解

    引言 multiprocessing是一个用于产生多进程的包,与threading模块的API类似.multiprocessing既可以实现本地的多进程,也可以实现远程的多进程.通过使用多个子进程而非 ...

  10. for循环小九九乘法表

    for(int i=1;i<=9;i++) { for(int j=1;j<=i;j++) { System.out.print(i+"*"+j+"=&quo ...