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的实例化,初始化过程等。

相关推荐
LuckyLay9 分钟前
Spring学习笔记_27——@EnableLoadTimeWeaving
java·spring boot·spring
Stringzhua16 分钟前
【SpringCloud】Kafka消息中间件
spring·spring cloud·kafka
向阳121822 分钟前
Dubbo负载均衡
java·运维·负载均衡·dubbo
Gu Gu Study32 分钟前
【用Java学习数据结构系列】泛型上界与通配符上界
java·开发语言
WaaTong1 小时前
《重学Java设计模式》之 原型模式
java·设计模式·原型模式
m0_743048441 小时前
初识Java EE和Spring Boot
java·java-ee
AskHarries1 小时前
Java字节码增强库ByteBuddy
java·后端
小灰灰__1 小时前
IDEA加载通义灵码插件及使用指南
java·ide·intellij-idea
夜雨翦春韭1 小时前
Java中的动态代理
java·开发语言·aop·动态代理
程序媛小果2 小时前
基于java+SpringBoot+Vue的宠物咖啡馆平台设计与实现
java·vue.js·spring boot