springboot-2.3.x最新版源码阅读环境搭建(基于gradle构建)

 更新时间:2020年08月10日 10:44:10   作者:smart哥  
这篇文章主要介绍了springboot-2.3.x最新版源码阅读环境搭建(基于gradle构建),需要的朋友可以参考下

一、前言

跟很多小伙伴聊天,发现一个严重的问题,很多小伙伴横向发展的貌似很不错,很多技术都能说出一二,但是如果在某个技术上深挖一下就不行了,问啥啥不会。就拿springboot来说,很多同学止步于springboot的应用,再往深处就一问三不知了,那么如何破局呢?smart哥认为最好的办法就是直捣黄龙,要把一个技术理解透了,听别人讲一万遍原理,不如自己撕一遍源码。

要阅读源码那就首先得先搭建源码阅读环境,那么本篇文章就来介绍下Spring Boot的源码环境搭建。 鉴于spring团队已经全面抛弃maven构建工具而选用gradle来构建,而且网上目前看来还没有文章介绍springboot最新版2.3.x的gradle构建(绝大多数都是maven构建),那么本篇文章就是基于gradle来构建最新版springboot2.3.2的源码阅读环境。

二、环境准备

1、git

拉取源码使用

2、jdk8及以上

一般小伙伴机器上都已经装好了

image-20200707211846249.jpg

3、gradle6.5.1

打开 https://services.gradle.org/distributions/ 选择最新版本:gradle-6.5.1-all.zip(all版本是带源码的)

在这里插入图片描述

下载解压后目录结构如下:

在这里插入图片描述

设置环境变量:

在这里插入图片描述

在这里插入图片描述

完成后打开cmd,执行

gradle -v

在这里插入图片描述

表示已经安装成功,版本为6.5.1

4、idea2020.1.2

(网上很多朋友表示idea2020之前的版本导入时始终有问题,建议升级到2020.1版本,smart哥当前使用的就是2020.1.2版本)

不得不说2020.1.2版本真香,之前的版本很多bug都在2020.1中得到修复。那些个bug真的会让人奔溃。

注意:springboot源码构建、编译及冒烟测试会非常的耗内存,建议内存不足16g的小伙伴升级下机器内存,最少16g。

三、下载源码

从官方仓库 https://github.com/spring-projects/spring-boot Fork 出属于自己的仓库。

  • 为什么要 Fork ?既然开始阅读、调试源码,我们可能会写一些注释,有了自己的仓库,可以进行自由的提交。
  • 本文使用的 Springboot 版本为最新的 2.3.x的分支代码 (2.3.2.BUILD-SNAPSHOT)。
  • 使用 git 从 Fork 出来的仓库拉取代码,注意这里为什么不拉取master分支呢?

因为smart哥刚开始就是拉取的master分支,但是master分支依赖的spring版本为spring-5.3.0-M1版本,该版本非稳定版本,而且编译到最后会出现问题,报一些spring模块的5.3.0-M1.jar包不存在或无法下载等一些莫名其妙的错误, 所以我这边拉取的是2.3.x分支,这个分支依赖的spring版本为5.2.7.RELEASE版本。所以我就git clone 2.3.x分支到本地,然后再导入idea中。

具体过程如下:

1、打开 https://github.com/spring-projects/spring-boot,点击右上角Fork即可,这样就把spring仓库fork到自己的仓库中了。

在这里插入图片描述

2、选择一个目录,我的是E:\mypro\IdeaProjects\spring-boot-2.3.1,空白处右击Git Bash Here

执行:

git clone -b 2.3.x https://github.com/spring-projects/spring-boot.gi

下载到本地

在这里插入图片描述

四、开始构建

1、打开idea后,【File】->【Open…】,打开刚拉取的spring-boot源码,点击ok即可打开,如下图:

在这里插入图片描述

打开之后,gradle会自动构建,开始下载gradle-6.4-bin.zip工具包,idea中还有一些地方需要设置,所以先不构建,点击取消,如下图:

image-20200708172146097.jpg

取消后如下图:

在这里插入图片描述

2、选择【File】->【project Structure…】,打开后点击左侧Project,然后Project SDK选择java version 1.8,Project language level选择8,如下图:

在这里插入图片描述

接下来,Modules选择Project SDK 1.8,点击ok即可

在这里插入图片描述

3、设置完毕之后,打开工程下的gradle->wrapper下的gradle-wrapper.properties文件,注释掉:

#distributionUrl=https\://services.gradle.org/distributions/gradle-6.4-bin.zip

换成本地的gradle-6.5.1-all.zip,这个版本是当前最新版,而且是带源码的。

distributionUrl=file:///e:/dev_env/gradle-6.5.1-all.zip

如图所示:

在这里插入图片描述

4、修改工程下的buildSrc下的build.gradle文件,找到如下代码段,添加阿里云镜像(不添加的话几个小时也构建不完)

repositories {
 //加上阿里云镜像
 maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
 maven { url 'https://maven.aliyun.com/nexus/content/repositories/jcenter' }
 maven { url "https://repo.spring.io/plugins-release" }
 mavenCentral()
 gradlePluginPortal()
 maven { url "https://repo.spring.io/release" }
}

如图:

在这里插入图片描述

5、继续修改同目录下的settings.gradle文件,这是全局配置文件,也要加上阿里云镜像,找到如下代码块,修改如下:

pluginManagement {
 repositories {
  //加上阿里云镜像
  maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
  maven { url 'https://maven.aliyun.com/nexus/content/repositories/jcenter' }
  maven { url "https://repo.spring.io/plugins-release" }
  mavenCentral()
  gradlePluginPortal()
 }
 ......
}

如下图所示:

在这里插入图片描述

6、修改工程根目录下的build.gradle文件(前面修改的是buildSrc下的,注意区别),同样是加上阿里云镜像,红框中的代码需要全部加上,且只能加在该文件头部。

buildscript {
 repositories {
  maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
  maven { url 'https://maven.aliyun.com/nexus/content/repositories/jcenter' }
  maven { url "https://repo.spring.io/plugins-release" }
 }
}

在这里插入图片描述

还是这个文件,继续修改,往下找到如下图的代码块,加上阿里云镜像

allprojects {
 group "org.springframework.boot"

 repositories {
  //阿里云镜像
  maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
  maven { url 'https://maven.aliyun.com/nexus/content/repositories/jcenter' }
  mavenCentral()
  ......
 }
 ......
}

在这里插入图片描述

7、继续修改根目录下的全局配置文件settings.gradle,同样是加上阿里云镜像

pluginManagement {
 repositories {
  //阿里云镜像
  maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
  maven { url 'https://maven.aliyun.com/nexus/content/repositories/jcenter' }
  mavenCentral()
  ......
 }
 ......
} 

如下图所示:

在这里插入图片描述

8、ok,到此才可以开始愉快的构建,如下图,构建中。。。

在这里插入图片描述

经过一段时间之后,构建快结束的时候,执行test这一步的时候,出现问题(当然这一步可以省略,但是smart哥先天的强迫症不允许),于是开始破解之法。

在这里插入图片描述

这个问题乍一看是无从入手的,然后往上找到错误提示:

file:///E:/mypro/IdeaProjects/spring-boot-2.3.1/spring-boot/buildSrc/build/reports/tests/test/classes/org.springframework.boot.build.testing.TestFailuresPluginIntegrationTests.html#multiProjectParallel()

于是拷贝这一段地址在浏览器打开,如下图所示:

是一段测试报告

在这里插入图片描述

继续往下查找,找到问题关键所在,heap堆内存没有足够的空间,错误如下:

在这里插入图片描述

9、我本机是16g内存,于是修改idea的bin目录下的idea.exe.vmoptions文件,修改idea的初始化内存和最大内存参数:

-Xms1024m,-Xmx4096m

在这里插入图片描述
在这里插入图片描述

修改后的文件内容如下:

-server
-Xms1024m
-Xmx4096m
-XX:ReservedCodeCacheSize=500m
-XX:+UseConcMarkSweepGC
-XX:SoftRefLRUPolicyMSPerMB=50
-ea
-XX:CICompilerCount=2
-Dsun.io.useCanonPrefixCache=false
-Djdk.http.auth.tunneling.disabledSchemes=""
-XX:+HeapDumpOnOutOfMemoryError
-XX:-OmitStackTraceInFastThrow
-Djdk.attach.allowAttachSelf=true
-Dkotlinx.coroutines.debug=off
-Djdk.module.illegalAccess.silent=true
-Dfile.encoding=UTF-8

10、重新编译还是报错,于是打开【File】->【Settings】,【Build,Execution,Deployment】->【Compiler】,Build process heap size(Mbytes)改成2000

在这里插入图片描述

11、重新编译还是报错,继续修改buildSrc目录下的gradle.properties文件,新增如下配置:

#新增如下配置,解决heap堆内存空间不够问题
gradlePropertiesProp=gradlePropertiesValue
sysProp=shouldBeOverWrittenBySysProp
systemProp.system=systemValue
org.gradle.caching=false
org.gradle.jvmargs=-Xms2048m -Xmx4096m 
org.gradle.parallel=true
org.gradle.daemon=true
org.gradle.configureondemand=true

重点是:org.gradle.jvmargs=-Xms2048m -Xmx4096m

在这里插入图片描述

配置完重新构建,编译,最后还是报空间不足,于是将org.gradle.jvmargs内存扩大一倍,如下:初始4g,最大8g

在这里插入图片描述

修改完再次重新构建,编译,终于成功!!撒花!!7分10秒,时间还是很快的。

在这里插入图片描述

五、源码测试

1、在springboot-boot-tests模块下随便找一个spring-boot-smoke-test-hibernate52工程来进行冒烟测试,打开Hibernate52Application.java文件,直接执行main方法启动springboot,成功!

console中出现我们熟悉的图标。

在这里插入图片描述

2、下面进行单元测试,还是在spring-boot-smoke-test-hibernate52下的test目录中,打开Hibernate52ApplicationTests.java文件,在contextLoads()方法中加一段打印信息:

@Test
void contextLoads() {
 System.out.println("hibernate test....");
}

执行Run Test,OK,测试也是没有问题的,测试结果如下图:

在这里插入图片描述

至此,spring-boot的源码阅读环境全部搭建并测试完毕

六、问题及解决方案

1、TestFailuresPluginIntegrationTests > multiProjectParallel() FAILED
java.lang.AssertionError at TestFailuresPluginIntegrationTests.java:88

在这里插入图片描述

该问题是junit包下载超时,可能是我机器网络抽风了,刷新重新构建即可!

2、spring-websocket-5.3.0-M1.jar包找不到

如果小伙伴们拉取的是master分支,就像我在本文开头讲的那样,此时报spring-websocket-5.3.0-M1.jar包找不到,提示在下面的地址中查找。

但是 https://maven.aliyun.com/repository/grails-core/org/springframework/spring-websocket/5.3.0-M1/spring-websocket-5.3.0-M1.jar

这个链接明明是可以下载的,所以smart哥一头雾水,懵圈了很久。

在这里插入图片描述

经过smart哥多次刷新重新下还是无法下载,于是抛弃master分支,转而拉取2.3.x分支。

在这里插入图片描述

结语

到此这篇关于springboot-2.3.x最新版源码阅读环境搭建(基于gradle构建)的文章就介绍到这了,更多相关springboot源码阅读环境搭建内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java图形验证码生成工具类 web页面校验验证码

    java图形验证码生成工具类 web页面校验验证码

    这篇文章主要为大家详细介绍了java图形验证码生成工具类,web页面校验验证码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • Java使用FFmpeg处理视频文件的方法教程

    Java使用FFmpeg处理视频文件的方法教程

    这篇文章主要给大家介绍了关于Java使用FFmpeg处理视频文件的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • 基于mybatis中test条件中单引号双引号的问题

    基于mybatis中test条件中单引号双引号的问题

    这篇文章主要介绍了基于mybatis中test条件中单引号双引号的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01
  • JVM 命令行工具的使用

    JVM 命令行工具的使用

    造成Java应用出现性能问题的因素非常多,想要定位这些问题,一款优秀的性能诊断工具必不可少,本文主要介绍了JVM 命令行工具的使用,具有一定的参考价值,感兴趣的可以了解一下
    2024-04-04
  • Java实现生产者消费者问题与读者写者问题详解

    Java实现生产者消费者问题与读者写者问题详解

    这篇文章主要介绍了Java实现生产者消费者问题与读者写者问题详解,小编觉得挺不错的,这里分享给大家,供需要的亲朋好友参考。
    2017-11-11
  • java文件上传技术深入剖析

    java文件上传技术深入剖析

    这篇文章主要为大家详细介绍了java文件上传技术深入剖析,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • java中年月日的加减法使用示例

    java中年月日的加减法使用示例

    这篇文章主要介绍了java中年月日的加减法使用示例的相关资料,需要的朋友可以参考下
    2023-02-02
  • eclipse中自动生成javadoc文档的方法

    eclipse中自动生成javadoc文档的方法

    这篇文章主要介绍了eclipse中自动生成javadoc文档的方法,是实用eclipse开发Java程序时非常实用的技巧,对于进行Java项目开发具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-12-12
  • java学生成绩管理系统设计与实现

    java学生成绩管理系统设计与实现

    这篇文章主要介绍了java学生成绩管理系统设计与实现,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • mybatis的增删改查运用方式

    mybatis的增删改查运用方式

    这篇文章主要介绍了mybatis的增删改查运用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11

最新评论