【spring-framework 本地下载部署,以及环境搭建】

一、Spring源码下载(以5.2.8.RELEASE版本为例)

java 复制代码
# GitHub 地址
git clone --branch v5.2.8.RELEASE https://github.com/spring-projects/spring-framework.git


# gitee 地址
git clone --branch v5.2.8.RELEASE https://gitee.com/mirrors/spring-framework.git

二、Spring源码编译

java 复制代码
# Spring是基于Gradle构建的项目,所以在编译之前需要下载Gradle并配置环境变量
# 解压到指定的位置即可

https://mirrors.aliyun.com/macports/distfiles/gradle/gradle-6.8.1-bin.zip

三、配置环境变量

显示如下界面,则Gradle配置成功。

修改源码中Gradle的配置文件

java 复制代码
maven { url 'https://maven.aliyun.com/repository/public' }

找到gradle.properties文件,修改以下内容:

java 复制代码
version=5.2.8.RELEASE
org.gradle.jvmargs=-Xmx2048M
org.gradle.caching=true
org.gradle.parallel=true
org.gradle.configureondemand=true
org.gradle.daemon=true

找到build.gradle文件,修改以下内容:

java 复制代码
maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
maven { url 'https://maven.aliyun.com/nexus/content/repositories/jcenter'}

编译

java 复制代码
# 在spring-framework目录下打开cmd,执行以下内容,编译会慢一点,可以去摸会鱼

gradlew :spring-oxm:compileTestJava

注意:如果遇到编译失败,报错如下:核心的 HTTPS 握手失败(handshake_failure

java 复制代码
FAILURE: Build failed with an exception.

* What went wrong:
Execution failed for task ':buildSrc:compileJava'.
> Could not resolve all files for configuration ':buildSrc:compileClasspath'.
   > Could not resolve com.google.guava:failureaccess:1.0.1.
     Required by:
         project :buildSrc > com.google.guava:guava:28.2-jre
      > Could not resolve com.google.guava:failureaccess:1.0.1.
         > Could not get resource 'https://repo.maven.apache.org/maven2/com/google/guava/failureaccess/1.0.1/failureaccess-1.0.1.pom'.
            > Could not HEAD 'https://repo.maven.apache.org/maven2/com/google/guava/failureaccess/1.0.1/failureaccess-1.0.1.pom'.
               > Received fatal alert: handshake_failure
      > Could not resolve com.google.guava:failureaccess:1.0.1.
         > Could not get resource 'https://plugins.gradle.org/m2/com/google/guava/failureaccess/1.0.1/failureaccess-1.0.1.pom'.
            > Could not HEAD 'https://repo.maven.apache.org/maven2/com/google/guava/failureaccess/1.0.1/failureaccess-1.0.1.pom'.
               > Received fatal alert: handshake_failure
   > Could not resolve com.google.guava:listenablefuture:9999.0-empty-to-avoid-conflict-with-guava.
     Required by:
         project :buildSrc > com.google.guava:guava:28.2-jre
      > Could not resolve com.google.guava:listenablefuture:9999.0-empty-to-avoid-conflict-with-guava.
         > Could not get resource 'https://repo.maven.apache.org/maven2/com/google/guava/listenablefuture/9999.0-empty-to-avoid-conflict-with-guava/listenablefuture-9999.0-empty-to-avoid-conflict-with-guava.pom'.
            > Could not HEAD 'https://repo.maven.apache.org/maven2/com/google/guava/listenablefuture/9999.0-empty-to-avoid-conflict-with-guava/listenablefuture-9999.0-empty-to-avoid-conflict-with-guava.pom'.
               > Received fatal alert: handshake_failure
      > Could not resolve com.google.guava:listenablefuture:9999.0-empty-to-avoid-conflict-with-guava.
         > Could not get resource 'https://plugins.gradle.org/m2/com/google/guava/listenablefuture/9999.0-empty-to-avoid-conflict-with-guava/listenablefuture-9999.0-empty-to-avoid-conflict-with-guava.pom'.
            > Could not HEAD 'https://repo.maven.apache.org/maven2/com/google/guava/listenablefuture/9999.0-empty-to-avoid-conflict-with-guava/listenablefuture-9999.0-empty-to-avoid-conflict-with-guava.pom'.
               > Received fatal alert: handshake_failure
   > Could not resolve com.google.code.findbugs:jsr305:3.0.2.
     Required by:
         project :buildSrc > com.google.guava:guava:28.2-jre
      > Could not resolve com.google.code.findbugs:jsr305:3.0.2.
         > Could not get resource 'https://repo.maven.apache.org/maven2/com/google/code/findbugs/jsr305/3.0.2/jsr305-3.0.2.pom'.
            > Could not HEAD 'https://repo.maven.apache.org/maven2/com/google/code/findbugs/jsr305/3.0.2/jsr305-3.0.2.pom'.
               > Received fatal alert: handshake_failure
      > Could not resolve com.google.code.findbugs:jsr305:3.0.2.
         > Could not get resource 'https://plugins.gradle.org/m2/com/google/code/findbugs/jsr305/3.0.2/jsr305-3.0.2.pom'.
            > Could not HEAD 'https://repo.maven.apache.org/maven2/com/google/code/findbugs/jsr305/3.0.2/jsr305-3.0.2.pom'.
               > Received fatal alert: handshake_failure
   > Could not resolve com.google.j2objc:j2objc-annotations:1.3.
     Required by:
         project :buildSrc > com.google.guava:guava:28.2-jre
      > Could not resolve com.google.j2objc:j2objc-annotations:1.3.
         > Could not get resource 'https://repo.maven.apache.org/maven2/com/google/j2objc/j2objc-annotations/1.3/j2objc-annotations-1.3.pom'.
            > Could not HEAD 'https://repo.maven.apache.org/maven2/com/google/j2objc/j2objc-annotations/1.3/j2objc-annotations-1.3.pom'.
               > Received fatal alert: handshake_failure
      > Could not resolve com.google.j2objc:j2objc-annotations:1.3.
         > Could not get resource 'https://plugins.gradle.org/m2/com/google/j2objc/j2objc-annotations/1.3/j2objc-annotations-1.3.pom'.
            > Could not HEAD 'https://repo.maven.apache.org/maven2/com/google/j2objc/j2objc-annotations/1.3/j2objc-annotations-1.3.pom'.
               > Received fatal alert: handshake_failure

* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.

* Get more help at https://help.gradle.org

BUILD FAILED in 2s

解决方式如下:全局配置 Gradle 镜像

  1. 找到 Gradle 的全局配置目录:

    • Windows:C:\Users\你的用户名\.gradle
    • Linux/Mac:~/.gradle
  2. 在该目录下新建 / 修改 init.gradle 文件,写入以下内容:

    java 复制代码
    allprojects {
        repositories {
            // 强制优先使用阿里云镜像,注释掉原有的 mavenCentral()
            maven { url 'https://maven.aliyun.com/repository/public' }
            maven { url 'https://maven.aliyun.com/repository/google' }
            maven { url 'https://maven.aliyun.com/repository/gradle-plugin' }
            // 仅作为兜底(可注释)
            // mavenCentral()
            // gradlePluginPortal()
        }
    }
    
    // 全局配置 TLS 1.2 协议,解决握手失败
    settingsEvaluated { settings ->
        settings.extensions.extraProperties.set("https.protocols", "TLSv1.2")
    }
    
    // 强制指定依赖版本,避免解析冲突
    gradle.projectsLoaded {
        rootProject.allprojects {
            buildscript {
                configurations.all {
                    resolutionStrategy {
                        force 'com.google.guava:failureaccess:1.0.1'
                        force 'com.google.guava:listenablefuture:9999.0-empty-to-avoid-conflict-with-guava'
                        force 'com.google.code.findbugs:jsr305:3.0.2'
                        force 'com.google.j2objc:j2objc-annotations:1.3'
                        force 'com.google.guava:guava:28.2-jre'
                    }
                }
            }
        }
    }

再次编译:

java 复制代码
gradlew :spring-oxm:compileTestJava

如果报如下错误:Spring 源码的 build.gradle 文件中引用的 io.spring.gradle-enterprise-conventions 插件(版本 0.0.2)无法被解析,这个插件是 Spring 官方的企业级 Gradle 约定插件,普通公开仓库中没有这个版本,核心解决思路是移除 / 注释掉这个非必需的插件引用(该插件仅用于 Spring 内部构建规范,不影响源码编译)。

java 复制代码
FAILURE: Build failed with an exception.

* Where:
Build file 'D:\spring\spring-framework\build.gradle' line: 6

* What went wrong:
Plugin [id: 'io.spring.gradle-enterprise-conventions', version: '0.0.2'] was not found in any of the following sources:

- Gradle Core Plugins (plugin is not in 'org.gradle' namespace)
- Plugin Repositories (could not resolve plugin artifact 'io.spring.gradle-enterprise-conventions:io.spring.gradle-enterprise-conventions.gradle.plugin:0.0.2')
  Searched in the following repositories:
    Gradle Central Plugin Repository
    maven(https://maven.aliyun.com/repository/public)
    maven2(https://repo.spring.io/plugins-release)

* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.

* Get more help at https://help.gradle.org

BUILD FAILED in 38s

解决方式:

  1. 打开 Spring 源码根目录的 build.gradle 文件;
  2. 找到文件开头的插件引用部分(第 6 行左右),注释 / 删除 io.spring.gradle-enterprise-conventions 插件;

再次编译:

java 复制代码
gradlew :spring-oxm:compileTestJava

编译成功如下图:

使用IDEA打开

红色这行意思是:在解析依赖 xml-apis:xml-apis:2.0.2 时,发现这个版本的 POM 文件中声明了「版本迁移」------ 官方将 2.0.2 版本迁移 / 重定向到了 1.0.b2 版本。2.0.2 这个被我们在上面注释掉了,所以会出这个提示。

到此Spring源码就编译成功啦!可以愉快的去深入理解spring 体系的相关的源码了。

相关推荐
程序员泠零澪回家种桔子2 小时前
ReAct Agent 后端架构解析
后端·spring·设计模式·架构
刘宇涵492 小时前
根节点Java
java
zwjapple2 小时前
React + Java 技术面试完整指南
java·开发语言·jvm·react
秋邱2 小时前
Java匿名内部类的使用场景:从语法本质到实战优化全解析
android·java·开发语言·数据库·python
悟乙己2 小时前
anthropics Skills pptx深度解读:从官方规范到实战案例(二)
java·llm·pptx·skills·anthropics
程序员阿鹏2 小时前
RabbitMQ持久化到磁盘中有个节点断掉了怎么办?
java·开发语言·分布式·后端·spring·缓存·rabbitmq
资生算法程序员_畅想家_剑魔2 小时前
Java常见技术分享-20-多线程安全-进阶模块-并发集合与线程池-ThreadPoolExecutor
java·开发语言
乐之者v2 小时前
AI生成mybatis代码
java·mybatis
Fluency-112 小时前
94.二叉树的中序遍历
java