Mac搭建Spring5源码环境

在阅读Spring源码时,我们需要进行本地Debug来看看Spring的启动流程,在搭建Spring本地环境时,遇到许多坑,而且网上很多资料都不是最新的,导致花费了很多时间,下面分享下我的步骤。

本地环境配置

  • MacBook M3
  • Idea 2024.3.5
  • Java8
  • Gradle 5.6.4

1.配置Jdk8环境

  • 下载jdk8

Java官网下载适用于M芯片的jdk8版本,安装jdk。

  • 配置Java环境变量

终端执行命令:vim ~/.bash_profile,修改文件内容。

Shell 复制代码
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk-1.8.jdk/Contents/Home
export PATH=$PATH:$JAVA_HOME/bin

保存文件,终端执行命令:source ~/.bash_profile使配置生效。

  • 确保Java安装成功 终端执行命令:java -version

如果输出以上内容,Java就安装成功。

2.下载Spring5.2.x源码

GitHub下载Spring-5.2.x源码,解压到本地,查看源码中gradle/wrapper/gradle-wrapper.properties

可以看到Spring-5.2.x需要配置gradle5.6.4

3.配置Gradle环境

  • 下载Gradle

Gradle官网下载5.6.4版本gradle-5.6.4-bin.zip,解压到本地。

  • 终端执行命令:vim ~/.bash_profile,修改文件内容。
Shell 复制代码
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk-1.8.jdk/Contents/Home
export GRADLE_HOME=/Users/tyler/software/gradle-5.6.4
export PATH=$PATH:$GRADLE_HOME/bin:$JAVA_HOME/bin

保存文件,终端执行命令:source ~/.bash_profile使配置文件生效。

  • 确保Gradle安装成功

终端执行命令:gradle -v

如果输出以上内容,Gradle就安装成功。

4.配置Spring5.2.x源码Debug环境

  • 修改根目录下setting.gradle配置文件,在repositories配置项中新增阿里云仓库
  • 修改根目录下build.gradle配置文件,在repositories配置项中新增阿里云仓库
  • 预编译spring-oxm

在spring-framework-5.2.x根目标下,终端执行命令: gradle :spring-oxm:compileTestJava

终端输出以上内容说明编译成功。

  • Idea导入源码

打开Idea, 选择 File -> New -> Project from Existing Sources -> Navigate to directory -> Select build.gradle,导入源码。

  • 新建spring-demo Module

可以新建测试类来调试跟踪Spring启动过程,在Debug时会发现Debug不生效,需要设置Idea Gradle配置。

  • 设置Idea Gradle

5.编译Spring5.2.x源码可能遇到的问题

  • Kotlin: warnings found and -Weeror specified

解决步骤:删除spring-core模块Kotlin -Weeror参数

如果还是不解决问题,在项目根目录下build.gradle配置文件中,找到allWarningsAsErrors,改为false。

  • 找不到符号CoroutinesUtils
Java 复制代码
java: 找不到符号
符号: 变量 CoroutinesUtils
位置: 类 org.springframework.core.ReactiveAdapterRegistry.CoroutinesRegistrar

解决步骤:Idea File->Project Structure->Libraries->点击➕选择Java

选择Kotlin包依赖路径:spring-framework-5.2.x/spring-core/kotlin-coroutines/build/libs/kotlin-coroutines-5.2.26.BUILD-SNAPSHOT.jar

然后选择spring.spring-core.main。

成功之后可以看到Kotlin依赖。

如果还是报错,在Modules中,spring-core依赖中再添加一次,路径还是上面的。

  • Java: 找不到符号 InstrumentationSavingAgent

解决步骤:修改spring-context.gradle,添加compile(project(":spring-instrument"))

  • 找不到类AnnotationTransactionAspect

解决步骤:在GitHub下载适合自己Java版本的aspectj依赖,双击安装,插件市场安装aspectj插件。

Project Settings选择Facets点击➕,选择AspectJ,选择spring.spring-aop.amin和spring.spring-aspects.main。

更改编译器

  • ajc: GroovyDynamicElementReader cannot be resolved to a type

解决步骤:Java Compiler选择Delegate to Javac。

相关推荐
lynnlovemin11 小时前
云原生提速秘籍:Spring Boot转Spring Native实战指南
spring boot·spring·云原生·spring native
爱敲代码的憨仔12 小时前
Spring-AOP
java·后端·spring
手握风云-12 小时前
JavaEE 进阶第十五期:Spring 日志的笔墨艺术
java·spring·java-ee
知识即是力量ol12 小时前
一次完整的 Spring Security JWT 鉴权链路解析
java·后端·spring·鉴权·springsecurity
铁蛋AI编程实战13 小时前
Agentic AI/GPT-4o替代/Spring AI 2.0/国产大模型轻量化
java·人工智能·spring
树码小子13 小时前
SpringMVC(12)综合案例练习:图书管理系统(后续仍会使用)
spring·mvc
一起养小猫13 小时前
Flutter for OpenHarmony 实战:打造功能完整的云笔记应用
网络·笔记·spring·flutter·json·harmonyos
没有腰的嘟嘟嘟14 小时前
[特殊字符] 本地部署 Qwen3:4B 大模型并使用 Spring Boot 对接实践指南
spring·ai·spring ai
努力也学不会java14 小时前
【Spring Cloud】优雅实现远程调用-OpenFeign
java·人工智能·后端·spring·spring cloud
过期动态1 天前
Java开发中的@EnableWebMvc注解和WebMvcConfigurer接口
java·开发语言·spring boot·spring·tomcat·maven·idea