Spring源码调试环境搭建(IDEA)

文章目录

引言

无论是面试,还是工作,Spring源码都是一个非常值得学习的内容。在开发和调试 Spring应用程序时,有时候需要深入理解框架的内部实现以及解决一些复杂的问题。为了更好地理解和调试 Spring源码,我们可以搭建一个本地的源码调试环境。本文将详细介绍如何通过下载源码、配置开发环境和启动调试来搭建这样的环境。

开发环境

JDK:

确保安装了 JDK,建议使用 JDK 8 或更高版本。

IDE:

推荐使用 IntelliJ IDEA 或 Eclipse 等流行的 Java IDE。这里我们以 IntelliJ IDEA 为例。

构建工具:

Maven 或 Gradle。Spring Boot 新版本开始默认使用 Gradle,所以我们这里以 Gradle 为例。

搭建步骤

步骤一:下载 Spring Boot 源码

首先,我们需要获取 Spring Boot 的源代码。你可以通过以下方式获取:

从 GitHub 获取源码(推荐):

Spring Boot 的源码托管在 GitHub 上,你可以访问GitHub 页面spring官方代码。在页面右侧可以看到一个绿色的按钮 "Code",点击后可以选择下载 ZIP 文件或者使用 Git 克隆仓库到本地。

复制代码
左上角选择版本,进行下载,解压(我选择的是5.2.x)

步骤二:导入项目到 IntelliJ IDEA

IntelliJ IDEA,选择 File -> New -> Project from Existing Sources,然后选择 Spring项目的根目录。
选择gradle

等待加载

步骤三:处理build报错

报错一

项目导入后会自动编译,首先会报错:

bash 复制代码
POM relocation to an other version number is not fully supported in Gradle : xml-apis:xml-apis:2.0.2 relocated to xml-apis:xml-apis:1.0.b2.

解决方案:

项目根目录下的build.gradle文件中添加如下代码,指定xml-apis的版本为1.0.b2

bash 复制代码
configurations.all {
    resolutionStrategy {
        force 'xml-apis:xml-apis:1.0.b2'
    }
}

报错二

bash 复制代码
Build scan background action failed.
org.gradle.process.internal.ExecException: A problem occurred starting process 'command 'git''
	at org.gradle.process.internal.DefaultExecHandle.execExceptionFor(DefaultExecHandle.java:237)
	at org.gradle.process.internal.DefaultExecHandle.setEndStateInfo(DefaultExecHandle.java:214)
	at org.gradle.process.internal.DefaultExecHandle.failed(DefaultExecHandle.java:364)
	at org.gradle.process.internal.ExecHandleRunner.run(ExecHandleRunner.java:87)
	at org.gradle.internal.operations.CurrentBuildOperationPreservingRunnable.run(CurrentBuildOperationPreservingRunnable.java:38)
	at org.gradle.internal.concurrent.ExecutorPolicy$CatchAndRecordFailures.onExecute(ExecutorPolicy.java:64)
	at org.gradle.internal.concurrent.ManagedExecutorImpl$1.run(ManagedExecutorImpl.java:48)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
	at org.gradle.internal.concurrent.ThreadFactoryImpl$ManagedThreadRunnable.run(ThreadFactoryImpl.java:56)
	at java.lang.Thread.run(Thread.java:748)
Caused by: net.rubygrapefruit.platform.NativeException: Could not start 'git'
	at net.rubygrapefruit.platform.internal.DefaultProcessLauncher.start(DefaultProcessLauncher.java:27)
	at net.rubygrapefruit.platform.internal.WindowsProcessLauncher.start(WindowsProcessLauncher.java:22)
	at net.rubygrapefruit.platform.internal.WrapperProcessLauncher.start(WrapperProcessLauncher.java:36)
	at org.gradle.process.internal.ExecHandleRunner.startProcess(ExecHandleRunner.java:98)
	at org.gradle.process.internal.ExecHandleRunner.run(ExecHandleRunner.java:71)
	... 7 more
Caused by: java.io.IOException: Cannot run program "git" (in directory "D:\wenjian\workspace\spring-framework-5.2.x\spring-framework-5.2.x"): CreateProcess error=2, ϵͳ�Ҳ���ָ�����ļ���
	at java.lang.ProcessBuilder.start(ProcessBuilder.java:1048)
	at net.rubygrapefruit.platform.internal.DefaultProcessLauncher.start(DefaultProcessLauncher.java:25)
	... 11 more
Caused by: java.io.IOException: CreateProcess error=2, ϵͳ�Ҳ���ָ�����ļ���
	at java.lang.ProcessImpl.create(Native Method)
	at java.lang.ProcessImpl.<init>(ProcessImpl.java:386)
	at java.lang.ProcessImpl.start(ProcessImpl.java:137)
	at java.lang.ProcessBuilder.start(ProcessBuilder.java:1029)
	... 12 more

BUILD SUCCESSFUL in 203ms

解决方案:

项目根目录下的build.gradle文件中注释掉

bash 复制代码
id 'io.spring.ge.conventions' version '0.0.7'

再次编译,成功!

测试步骤

新建module


修改build.gradle

新建module中的build.gradle 中的dependencies添加

bash 复制代码
compile(project(":spring-beans"))
compile(project(":spring-context"))

新建测试类


启动类:

java 复制代码
public class LufeiApplication {
	public static void main(String[] args) {
		AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(TestConf.class);
		System.out.println(context.getBean(User.class));
	}
}

配置类:

java 复制代码
package com.lufei;

import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;

@Configuration
@ComponentScan("com.lufei")
public class TestConf {
}

实体类

java 复制代码
package com.lufei;

import org.springframework.stereotype.Component;

@Component
public class User {

	private Integer id;

	private String name;

	public Integer getId() {
		return id;
	}

	public void setId(Integer id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}
}

启动测试

如下,可以打印出对象地址了。后续可以自己debug spring的源码研究研究bean的实例化,初始化过程等。

相关推荐
李小白663 分钟前
JavaEE初阶复习(JVM篇)
java·jvm·java-ee
Easonmax12 分钟前
【JavaEE】网络原理详解
java·java-ee
movie__movie14 分钟前
Spring AI MCP 客户端实战:轻松连接高德地图等工具
数据库·人工智能·spring
阿杜杜不是阿木木17 分钟前
使用ollama部署本地大模型(没有GPU也可以),实现IDEA和VS Code的git commit自动生成
linux·git·vscode·ai·intellij-idea·ollama
java_学习爱好者23 分钟前
SpringBoot配置文件多环境开发
java
别来无恙✲35 分钟前
SpringBoot启动方法分析
java·springboot·场景设计
Jay_See42 分钟前
Leetcode——239. 滑动窗口最大值
java·数据结构·算法·leetcode
DKPT1 小时前
Eclipse,MyEclipse,IDEA,Vscode这些编译器和JDK的相爱相杀
java·eclipse·编辑器·intellij-idea·myeclipse
肠胃炎1 小时前
真题246—矩阵计数
java·线性代数·算法·矩阵·深度优先
前行的小黑炭2 小时前
设计模式:为什么使用模板设计模式(不相同的步骤进行抽取,使用不同的子类实现)减少重复代码,让代码更好维护。
android·java·kotlin