spring源码本地编译,按网上的博客参考资料的操作步骤,总是会出现各种莫名其妙的错误。根据错误信息找解决方案,但在自己的环境下又总是编译不过去。结合参加培训学习Jack老师提供的方法,自己多种方式尝试,最终编译成功了。
为了验证自己的方式是否有失误的地方,全部过程我自己走了大概5遍,详细记录下每个步骤。如果按1天8小时计的话,为了这个源码编译至少花了3~4天时间。我觉得是值得的,为后面的源码阅读扫除一个拦路虎。
仅以此篇记录踩到的坑,为同样想读源码的同学可以在编译这一步少花一些时间,也可以后面源码阅读增加自信心。同时感谢在网上留下博客的同学,给予我相当多的帮助,这也是我想写这篇文章的原因。
参考博客:
https://www.it610.com/article/1295306604677242880.htm
https://www.cnblogs.com/haoxianrui/p/12825586.html
https://www.cnblogs.com/jhj117/p/5455081.html
idea 2019.3.3
gradle-5.6.4版本(对源码里面的版本,版本需要一致,否则编译过程会出现各种异常)
jdk1.8 or 以上版本
spring-5.2.8.RELEASE
系统:win7 or 以上
选择gitee下载速度快,官网速度非常慢,耗时约60s
git clone --branch v5.2.8.RELEASE https://gitee.com/Z201/spring-framework.git
查看文件路径:/gradle/wrapper/gradle-wrapper.properties
对应的gradle版本:gradle-5.6.4-bin.zip
# gradle 下载地址
https://services.gradle.org/distributions/
选择版本: gradle-5.6.4-bin.zip
下载到本机,并解压到指定路径
配置环境变量
变量名:GRADLE_HOME
变量值:A:\java_about\gradle-5.6.4
在Path加上 ;%GRADLE_HOME%\bin
目录:spring-framework/gradle/wrapper
修改 distributionUrl=file:///A:/java_about/gradle-5.6.4-bin.zip #(本机的所在路径)
先查看idea的kotlin版本,查看路径:File->Setting->Plugins,搜索kotlin,如果还没安装过先安装一下。
目标文件:build.gradle 在根目录下
因为该plugins不注释,会发生很多不可预期的错误,
搜索关键字:io.spring.gradle-enterprise-conventions
注释如下:
// id 'io.spring.gradle-enterprise-conventions' version '0.0.2'
如果不一致,修改成跟idea的kotlin的版本号一样,我的版本号为1.3.61,而Spring-5.2.8.RELEASE对应kotlin的版本号是1.3.72,所以需要修改。需要修改的地方有2处
搜索关键字:kotlin.jvm , kotlin-bom
为仓库添加上阿里镜像,目的是加快资源下载,编译速度加快。行号约279,在dependencyManagement下的repositories 添加:
maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
maven { url 'https://maven.aliyun.com/nexus/content/repositories/jcenter'}
为插件仓库添加上阿里镜像,行号约2,在pluginManagement下的repositories 添加:
maven { url "https://maven.aliyun.com/repository/public" }
目标文件:gradle.properties
1.增加内存分配 -- 这个按本机的内存去分配,我的是16G
org.gradle.jvmargs=-Xmx2048M
2.按需配置
org.gradle.configureondemand=true
3.开启守护进程
org.gradle.daemon=true
依次点击File->New->Project from Existing Sources,选择源码包路径下的build.gradle文件完成源码导入
可以预先打开idea配置,也可在导入过程中去配置(导入后会出现一个进度条,选择backgroud后台运行)
操作路径:File->Setting->Build,Execution,Deployment->Build Tools->Gradle
以上设置完成后,就是等待过程了,具体多长时间看网速,我的导入编译完成耗时约11m 57s,一次性成功。
编译日志内容如下:
Starting Gradle Daemon...
Gradle Daemon started in 4 s 477 ms
> Task :buildSrc:compileJava
> Task :buildSrc:compileGroovy NO-SOURCE
> Task :buildSrc:pluginDescriptors
> Task :buildSrc:processResources
> Task :buildSrc:classes
> Task :buildSrc:jar
> Task :buildSrc:assemble
> Task :buildSrc:pluginUnderTestMetadata
> Task :buildSrc:compileTestJava NO-SOURCE
> Task :buildSrc:compileTestGroovy NO-SOURCE
> Task :buildSrc:processTestResources NO-SOURCE
> Task :buildSrc:testClasses UP-TO-DATE
> Task :buildSrc:test NO-SOURCE
> Task :buildSrc:validateTaskProperties
> Task :buildSrc:check
> Task :buildSrc:build
CONFIGURE SUCCESSFUL in 11m 57s
在idea底部菜单栏,切到Terminal菜单,输入spring-oxm的预编译命令:
gradlew :spring-oxm:compileTestJava
在spring-context添加测试类,测试验证是否能编译通过,拿到实例的对象。
为了快速定位到,先添加测试的package: com.elephant.bean , 创建Student实体类
package com.elephant.bean;
import org.springframework.stereotype.Service;
@Service
public class Student {
private String username = "elephant";
private String password;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
spring-test.xml ,目录在test/resources,内容如下:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
">
<context:component-scan base-package="com.elephant"/>
beans>
为了快速定位到,先添加测试的package: com.elephant.test , 创建MyTest类
package com.elephant.test;
import com.elephant.bean.Student;
import org.junit.Test;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MyTest {
@Test
public void test1() {
ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("spring-test.xml");
Student student = (Student)applicationContext.getBean("student");
System.out.println(student.getUsername());
System.out.println("我获取用户名了:"+student.getUsername());
}
}
在类MyTest 方法 test1() 右击Run,然后等待运行结果。
耗时约 1m 36s
预期结果:成功打印出student的userName , 结果符合预期,成功!
我获取用户名了:elephant
BUILD SUCCESSFUL in 1m 36s
50 actionable tasks: 26 executed, 7 from cache, 17 up-to-date
The remote build cache was disabled during the build due to errors.
18:34:24: Tasks execution finished ':spring-context:cleanTest :spring-context:test --tests "com.elephant.test.MyTest.test1"'.