搭建源码调试环境—RocketMQ源码分析(一)

简介: 在正式开始搭建调试环境之前,我们先了解一下RockeMQ源码的整体架构。这是因为掌握了整体架构,可以让我们迅速了解各个方面的特性,并且可以方便我们后续快速定位功能模块对应的代码文件。话不多说,我们开始看RocketMQ目录结构。

你好,我是程序员Alan,很高兴遇见你。

一、RocketMQ目录结构

在正式开始搭建调试环境之前,我们先了解一下RockeMQ源码的整体架构。

这是因为掌握了整体架构,可以让我们迅速了解各个方面的特性,并且可以方便我们后续快速定位功能模块对应的代码文件。话不多说,我们开始看RocketMQ目录结构。

acl: 权限控制。可以给话题指定权限,只有拥有权限的消费者才可以进行消费。

broker: RocketMQ 的 Broker 相关代码,用来启动 Broker 进程。Broker 就是用来收客户端发的消息、存储消息传、递消息给消费端的组件。

client:RocketMQ 的 Producer、Consumer 这些客户端的代码,用来生产消息、消费消息。

common:公共模块。

distribution:用来部署 RocketMQ 的,比如 bin 目录 ,conf 目录。

example: RocketMQ 的用例。

filter:RocketMQ 过滤器。

namesvr:NameServer 的源码。NameServer 就是所有 Broker 都需要注册的地方,注册中心。

remoting:RocketMQ 的远程网络通信模块。

srvutil:工具类。

store:消息存储。

style:代码检查。

tools:命令行监控工具相关。

二、获取RocketMQ源码

源码地址:https://github.com/apache/rocketmq/tree/rocketmq-all-5.0.0

我下载的是5.0.0版本,你也可以在github下载其他版本。

如果下载遇到困难,可以留言或者私信我。

三、导入源码

代码下载解压之后,使用IDEA工具导入。

四、下载依赖

先确认Maven目录地址,再刷新,等待依赖下载完成。

五、启动RocketMQ的NameServer

5.1 配置NameServer启动参数

5.1.1 Edit Configurations,配置 ROCKETMQ_HOME 环境变量

5.2 拷贝配置文件

Value 的文件夹是用来部署 RocketMQ 的,里面包括 bin 目录 ,conf 目录,store目录。

我们首先创建一个文件夹,并创建三个子文件夹,分别是 bin  ,conf ,store。

文件夹都创建好之后,我们把RocketMQ自带的配置文件拷贝过来。

需要拷贝的文件夹是源码目录 distribution 目录中的 broker.conf、logback_namesrv.xml、logback_broker.xml。

5.3 修改 logback 日志配置文件

打开 logback_namesrv.xml、logback_broker.xml, ${user.home} 全局替换为之前配置的 ROCKETMQ_HOME 目录

5.4 修改broker配置文件

打开 broker.conf 文件,把下面的配置拷贝进去。

namesrvAddr=127.0.0.1:9876

brokerIP1=127.0.0.1

storePathRootDir=D:/Project/ROCKETMQ_HOME/store

storePathCommitLog=D:/Project/ROCKETMQ_HOME/store/commitlog

storePathConsumeQueue=D:/Project/ROCKETMQ_HOME/store/consumequeue

storePathIndex=D:/Project/ROCKETMQ_HOME/store/index

storeCheckpoint=D:/Project/ROCKETMQ_HOME/store/checkpoint

abortFile=D:/Project/ROCKETMQ_HOME/store/abort


5.5 启动NameServer

六、启动RocketMQ的Broker

6.1 配置Broker的启动参数

6.2 启动Broker

6.3 查看启动日志

打开 ROCKETMQ_HOME /logs/rocketmqlogs 目录下的 broker.log 或者 namesrv.log 文件看启动的详细日志。

七、测试生产消息

7.1 我们可以直接使用源码自带的示例来做测试。

7.2 打开 Producer.java, 设置 name server addresses

7.3 启动 Producer

7.4 成功发送消息

八、测试消费消息

我们继续使用自带的测试用例。

8.2 打开 Consumer.java, 设置 name server addresses

8.3 启动消费者

8.4 成功消费消息

九、使用RocketMQ Dashboard 查看 RocketMQ运行情况

站在巨人的肩膀上

  • 悟空聊架构
相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
5月前
|
传感器 网络协议 物联网
手把手教你在 Windows 环境中搭建 MQTT 服务器
手把手教你在 Windows 环境中搭建 MQTT 服务器
391 0
|
2月前
|
消息中间件 存储 监控
深度写作:深入源码理解MQ长轮询优化机制
【11月更文挑战第22天】在分布式系统中,消息队列(Message Queue, MQ)扮演着至关重要的角色。MQ不仅实现了应用间的解耦,还提供了异步消息处理、流量削峰等功能。而在MQ的众多特性中,长轮询(Long Polling)机制因其能有效提升消息处理的实时性和效率,备受关注。
85 12
|
2月前
|
消息中间件 存储 Java
深入源码理解MQ长轮询优化机制
【11月更文挑战第22天】在分布式系统中,消息队列(MQ)作为一种重要的中间件,广泛应用于解耦、异步处理、流量削峰等场景。其中,延时消息和定时消息作为MQ的高级功能,能够进一步满足复杂的业务需求。为了实现这些功能,MQ系统需要进行一系列优化,长轮询机制便是其中的关键一环。本文将深入探讨MQ如何设计延时消息和定时消息的优化机制,特别是长轮询机制的实现原理及其在Java中的模拟实现。
48 2
|
7月前
|
消息中间件 数据可视化 Go
Rabbitmq 搭建使用案例 [附源码]
Rabbitmq 搭建使用案例 [附源码]
57 0
|
4月前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
8月前
|
消息中间件 存储 RocketMQ
RocketMQ源码分析之事务消息实现原理下篇-消息服务器Broker提交回滚事务实现原理
RocketMQ源码分析之事务消息实现原理下篇-消息服务器Broker提交回滚事务实现原理
|
3月前
|
传感器 数据可视化 网络协议
DIY可视化整合MQTT生成UniApp源码
DIY可视化整合MQTT生成UniApp源码
63 0
|
6月前
|
消息中间件 Java Apache
消息队列 MQ使用问题之如何在内外网环境下使用单组节点单副本模式
消息队列(MQ)是一种用于异步通信和解耦的应用程序间消息传递的服务,广泛应用于分布式系统中。针对不同的MQ产品,如阿里云的RocketMQ、RabbitMQ等,它们在实现上述场景时可能会有不同的特性和优势,比如RocketMQ强调高吞吐量、低延迟和高可用性,适合大规模分布式系统;而RabbitMQ则以其灵活的路由规则和丰富的协议支持受到青睐。下面是一些常见的消息队列MQ产品的使用场景合集,这些场景涵盖了多种行业和业务需求。
|
7月前
|
消息中间件 Kubernetes Android开发
消息队列 MQ产品使用合集之如何在kubernetes环境里面部署
消息队列(MQ)是一种用于异步通信和解耦的应用程序间消息传递的服务,广泛应用于分布式系统中。针对不同的MQ产品,如阿里云的RocketMQ、RabbitMQ等,它们在实现上述场景时可能会有不同的特性和优势,比如RocketMQ强调高吞吐量、低延迟和高可用性,适合大规模分布式系统;而RabbitMQ则以其灵活的路由规则和丰富的协议支持受到青睐。下面是一些常见的消息队列MQ产品的使用场景合集,这些场景涵盖了多种行业和业务需求。