如何调试 Java 开源项目源码,记一种源码导入开发工具并调试的通用方法

楔子

说起读开源项目源码,很多朋友觉得高大上、大佬牛逼,云云~

挡在很多人面前的不是源码怎么读,而是不知道如何导入源码到开发工具以及如何调试源码。

本文将以 spring-cloud-gateway 源码导入一个简单的 SpringBoot 项目中举例,目的就是给读者一个导入开源项目源码并调试的简单方法。

看文过程中感觉有不明白的地方欢迎评论留言,如果本文帮到了你,本人不胜荣幸的同时,也欢迎为本文点个大拇哥 😅

准备工作

1、默认大家本地有装 IDEA、Maven、Git,Java 程序员通识就不再细述。

2、下载源码 https://github.com/spring-cloud/spring-cloud-gateway.git

3、切换 tag 创建分支 v3.0.2

本例中切换分支有其原因:根据BOM spring-cloud-dependencies-parent 中定义的版本对应的仓库tag 正是v3.0.2

4、使用 https://start.spring.io/ 初始化一个demo,引入 spring-cloud-starter-gateway依赖,使用Java 8,项目名等其他信息默认

点击 GENERATE 下载生成的代码压缩包,解压到自己的目录

5、目前 demo 与 spring-cloud-gateway 源码都放到了 ~/WorkSpace/gitRepo 目录下了。

接下来,开始导入项目与源码

导入项目与源码

1、导入demo工程

给出一下demo的pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.4.4</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>
	<groupId>com.example</groupId>
	<artifactId>demo</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<name>demo</name>
	<description>Demo project for Spring Boot</description>
	<properties>
		<java.version>1.8</java.version>
		<spring-cloud.version>2020.0.2</spring-cloud.version>
	</properties>
	<dependencies>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-gateway</artifactId>
		</dependency>

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
	</dependencies>
	<dependencyManagement>
		<dependencies>
			<dependency>
				<groupId>org.springframework.cloud</groupId>
				<artifactId>spring-cloud-dependencies</artifactId>
				<version>${spring-cloud.version}</version>
				<type>pom</type>
				<scope>import</scope>
			</dependency>
		</dependencies>
	</dependencyManagement>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>

</project>

2、检查 gateway 相关依赖是否引入

直接输入关键字,搜索 gateway,查看是否有gateway相关依赖,这是我们一般引Maven依赖的方式。

3、引入 spring-cloud-gateway 源码工程

使用 spring-cloud-gateway 下的pom.xml 引入项目

等待依赖拉取完成,如下图所示

验证

1、验证External Libraries 下是否仍有 spring-cloud-starter-gateway 依赖

直接用搜索关键字来查

2、修改 spring-cloud-gateway 子工程源码,测试demo是否使用spring-cloud-gateway源码工程

把demo工程run起来,什么也不需要配置,直接看日志输出

如上图,当前依赖的是源码了,可以放心的加注释与Debug了。

原理

这个方法是利用了Maven依赖搜索顺序做到的。

源码依赖 > 本地仓库依赖 > 远程仓库依赖

ps:Gradle也是类似的

详细解释就是引入 spring-cloud-gateway 的 pom.xml时,会连带着将其子工程均依赖到当前工作空间中,对于 Maven 而言,这几个子工程的pom.xml是它首先要搜索的地方,这些pom.xml正是定义坐标的地方。

当Maven按demo工程的pom找坐标时,会按下图的坐标到所有引进来的工程中先找上一波

当找到spring-cloud-gateway源码工程时,发现还有子工程,再到子工程找一遍

找到 spring-cloud-starter-gateway 工程的pom.xml时,就会将其源码依赖进来

由于SpringBoot 和 SpringCloud 的 Starter 都是虚包,spring-cloud-starter-gateway 会把其他相关依赖引到项目中。

后话

写这篇文章做个记录,希望能帮到有需要的人,如果本文对你有所启发,点个推荐再走呗~

我是 Hellxz,一个Java/Vue/K8s/DevOps等涉猎广泛的软件工程师!

细水长流,我们下次再见,peace~


本文同步发布于我的CSDN博客 https://blog.csdn.net/u012586326?spm=1001.2101.3001.5343

posted @ 2021-04-15 01:27  东北小狐狸  阅读(802)  评论(0编辑  收藏  举报