Dubbo3 源码系列 -- 环境准备
2022/2/4 17:12:31
本文主要是介绍Dubbo3 源码系列 -- 环境准备,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
Dubbo3 源码系列 -- 环境准备
前言
工作中一直使用Dubbo项目,借着这次机会通过源码的方式来学习下Dubbo的源码内容。目前市面上很多都是的Dubbo2系列的教程;就连目前的Dubbo的官方文档也还在完善中,既然是学习,那就
just do it
!
环境搭建
前置环境
- Maven
- Git
- JDK
- IntelliJ IDEA
源码构建
拉取代码
git clone git@github.com:ln0491/dubbo.git
执行编译
mvn clean install -Dmaven.test.skip=true
这里推荐使用 mvnd
编译,速度实测要快3倍左右。 (关于mvnd的代码研究的请参考:mvnd的GitHub)
mvnd clean install -Dmaven.test.skip=true -Dquickly
这里需要等待一会儿,去喝杯水吧!
导入IDEA
mvn idea:idea
模块介绍
-
dubbo-common 模块
Dubbo 的一个公共模块,其中有很多工具类以及公共逻辑,例如Dubbo SPI 实现、时间轮实现、动态编译器等
-
dubbo-remoting 模块
Dubbo 的远程通信模块,其中的子模块依赖各种开源组件实现远程通信。在 dubbo-remoting-api 子模块中定义该模块的抽象概念,在其他子模块中依赖其他开源组件进行实现,例如,dubbo-remoting-netty4 子模块依赖 Netty 4 实现远程通信,dubbo-remoting-zookeeper 通过 Apache Curator 实现与 ZooKeeper 集群的交互。
-
dubbo-rpc 模块
Dubbo 中对远程调用协议进行抽象的模块,其中抽象了各种协议,依赖于 dubbo-remoting 模块的远程调用功能。dubbo-rpc-api 子模块是核心抽象,其他子模块是针对具体协议的实现,例如,dubbo-rpc-dubbo 子模块是对 Dubbo 协议的实现,依赖了 dubbo-remoting-netty4 等 dubbo-remoting 子模块。 dubbo-rpc 模块的实现中只包含一对一的调用,不关心集群的相关内容。
-
dubbo-registry 模块
Dubbo 中负责与多种开源注册中心进行交互的模块,提供注册中心的能力。其中, dubbo-registry-api 子模块是顶层抽象,其他子模块是针对具体开源注册中心组件的具体实现,例如,dubbo-registry-zookeeper 子模块是 Dubbo 接入 ZooKeeper 的具体实现。
-
dubbo-monitor 模块
Dubbo 的监控模块,主要用于统计服务调用次数、调用时间以及实现调用链跟踪的服务。
-
dubbo-config 模块
Dubbo 对外暴露的配置都是由该模块进行解析的。例如,dubbo-config-api 子模块负责处理 API 方式使用时的相关配置,dubbo-config-spring 子模块负责处理与 Spring 集成使用时的相关配置方式。有了 dubbo-config 模块,用户只需要了解 Dubbo 配置的规则即可,无须了解 Dubbo 内部的细节。
-
dubbo-metadata 模块
Dubbo 的元数据模块(本课程后续会详细介绍元数据的内容)。dubbo-metadata 模块的实现套路也是有一个 api 子模块进行抽象,然后其他子模块进行具体实现
-
dubbo-configcenter 模块
Dubbo 的动态配置模块,主要负责外部化配置以及服务治理规则的存储与通知,提供了多个子模块用来接入多种开源的服务发现组件
-
dubbo-demo 模块
Dubbo的官方提供的使用案例,可以通过注解、API、XML方式、SpringBoot等相关的演示案例
案例运行
这里通过
dubbo-demo-annotation
为例,测试编译效果。提前启动zookeeper
吧。
- 启动
org.apache.dubbo.demo.provider.Application
- 启动
org.apache.dubbo.demo.consumer.Application
总结
本文简单的搭建了Dubbo的源码工程,后续继续阅读的小伙伴可以 GitHub 的Fork
继续研究;并且简单介绍了Dubbo的模块和案例演示。
这篇关于Dubbo3 源码系列 -- 环境准备的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-25Java创意资料:新手入门的创意学习指南
- 2024-11-25JAVA对接阿里云智能语音服务资料详解:新手入门指南
- 2024-11-25Java对接阿里云智能语音服务资料详解
- 2024-11-25Java对接阿里云智能语音服务资料详解
- 2024-11-25JAVA副业资料:新手入门及初级提升指南
- 2024-11-25Java副业资料:入门到实践的全面指南
- 2024-11-25Springboot应用的多环境打包项目实战
- 2024-11-25SpringBoot应用的生产发布项目实战入门教程
- 2024-11-25Viite多环境配置项目实战:新手入门教程
- 2024-11-25Vite多环境配置项目实战入门教程