在一心想要学习Spring框架源码时,我们会遇到很多麻烦的问题。开始本文前,你只需要拥有一个装好IDEA的Ubuntu系统就可以愉快启程了。如果还没有IDEA,可以参考在Ubuntu上安装Intellij IDEA并创建桌面快捷方式,至于Git ,Gradle ,Java 可以选择事先安装好,也可以跟随本文在遇到对应问题时再安装。
环境信息
项目 | 版本号 | 是否需要提前安装好 |
---|---|---|
Ubuntu | 18.04 LTS | 是 |
Intellij IDEA | 2019.1.3 | 是 |
Git | 2.17.1 | 否 |
Gradle | 5.5 | 否 |
Java | 1.8 | 否 |
一、我们直奔主题Git源码:
URL:
https://github.com/spring-projects/spring-framework.git
问题1:Cannot Run Git
解决方案:如何在Ubuntu系统上安装Git
方案选择及理由:我选择了使用默认包安装Git(且我没有做设置Git的操作),因为我搭建的主要目标是上手一套源码阅读环境,所以快捷的方式更好。以下是指令:
sudo apt update
sudo apt install git
第一次执行时出现这个报错,且sudo apt update
执行过程中也有一些更新失败的报错。后来休息了一段时间我又重新回来做的,第二次用的是apt-get
sudo apt-get update
sudo apt install git
执行完成后重启IDEA,就可以Git spring-framework代码了
网上Ubuntu安装Git的文章中apt和apt-get指令都有,那有什么区别呢?
参考这篇文章Linux中apt与apt-get命令的区别与解释
* 简单补充几点:
apt
命令是在Ubuntu 16.04 引入的。apt-get
虽然没被弃用,但作为普通用户,还是应该首先使用apt
。- apt和apt-get命令之间的区别:
apt 命令 | 取代的命令 | 命令的功能 |
---|---|---|
apt install | apt-get install | 安装软件包 |
apt remove | apt-get remove | 移除软件包 |
apt purge | apt-get purge | 移除软件包及配置文件 |
apt update | apt-get update | 刷新存储库索引 |
apt upgrade | apt-get upgrade | 升级所有可升级的软件包 |
apt autoremove | apt-get autoremove | 自动删除不需要的包 |
apt full-upgrade | apt-get dist-upgrade | 在升级软件包时自动处理依赖关系 |
apt search | apt-cache search | 搜索应用程序 |
apt show | apt-cache show | 显示装细节 |
问题2:clone git慢
解决方案1:git clone速度太慢的解决办法
解决方案2(更推荐):
如果像我一样只是为了读spring源码,Gitee码云上有个快速的git地址
使用以下地址:
★https://gitee.com/mirrors/Spring-Framework.git
代替
https://github.com/spring-projects/spring-framework.git
Directory我仍然使用的是/spring-framework(而没用/Spring-Framework),是因为可以接着之前Github的下载结果继续git
二、导入项目到IDEA
我们已经有一个项目在~/IdeaProjects/spring-framework
下了,但是在打开项目时再次遇到问题:
问题3:Please, set the Gradle JVM option
解决方案:安装JDK1.8!Ubuntu18.04 安装Jdk1.8
官网下载JDK都要Oracle账号单点登录了,经常要下JDK的还是建议注册一个Oracle账号
问题4:官网下载JDK慢
有时候,下载个JDK要6个多小时,这谁顶得住啊?
解决方案:参考博客# JDK下载过慢的问题解决方案
华为镜像:https://repo.huaweicloud.com/java/jdk/
修改环境变量的时候用以下指令解决权限问题:
sudo su
vi /etc/profile
打开vi编辑器之后,G
跳到文档底部,按i
进入插入模式,并从光标当前位置开始输入;按a
进入插入模式,从目前光标所在位置的下一个位置开始输入文字;
按o
进入插入模式,并插入新的一行,从行首开始输入文字。
按x
删除字符,最后按ESC
并输入:qw
保存离开
source /etc/profile
java -version
*简单讲一下文件校验:
我下载的是https://repo.huaweicloud.com/java/jdk/8u202-b08/ 中的jdk-8u202-linux-x64.tar.gz
oracle官网checksum:
https://www.oracle.com/webfolder/s/digest/8u202checksum.html
FileName | CheckSum |
---|---|
jdk-8u202-linux-x64.tar.gz | sha256: 9a5c32411a6a06e22b69c495b7975034409fa1652d03aeb8eb5b6f59fd4594e0 |
md5: 0029351f7a946f6c05b582100c7d45b7 |
获取本地文件摘要的Shell指令:
sha256sum
md5sum
两者一校对,没毛病
安装好JDK后之后还没完:
- 选择Welcome to IntelliJ IDEA的右下角
Configure
->Structure for New Projects
- 点击
New..
选择刚才安装的JDK目录,例如我的/usr/local/jdk1.8.0
- 重新打开之前Git下来的源码
三、迫不及待开始编译源码:
问题5: spring源码编译需要gradle
解决方案:自己手动下载Gradle
cd /usr/local
sudo mkdir gradle
sudo unzip -d /usr/local/gradle ~/下载/gradle-5.5-bin.zip
这里为啥要建一个gradle文件夹呢?因为开发时常常会用到多个不同版本gradle,所以建个gradle放所有gradle文件
- 3.配置环境变量
sudo su
vi /etc/profile
source /etc/profile
- 4.验证
gradle -v
5.配置IDEA GRADLE_HOME
选择IDEA-File
-Settings
,打开设置,然后搜索gradle
,
选择Use local Gradle distribution
,输入Gradle home:
/usr/local/gradle/gradle-5.5
问题6: gradle下载依赖慢
解决方案:参考这篇博客Gradle配置解决下载速度慢问题
- 1.对Gradle进行全局的设置
cd ~/.gradle/
touch init.gradle
vi init.gradle
- 2.init.gradle中的内容:
allprojects{
repositories {
def REPOSITORY_URL = 'http://maven.aliyun.com/nexus/content/groups/public/'
all { ArtifactRepository repo ->
if(repo instanceof MavenArtifactRepository){
def url = repo.url.toString()
if (url.startsWith('https://repo1.maven.org/maven2') || url.startsWith('https://jcenter.bintray.com/') || url.startsWith('https://repo.maven.apache.org') || url.startsWith('https://repo.spring.io')) {
remove repo
}
}
}
maven {
url REPOSITORY_URL
}
}
}
如果不是从
maven.aliyun.com
下载还是从repo.spring.io
或者repo.maven.apache.org
下载,可能init.gradle还有些问题,比如https误写成http
等,建议立即停止build,修改init.gradle之后重新build。另外,整个build过程可能还有点耗时,但是至少Download时不会卡住了。
问题7:cglib和objenesis的编译错误
报错模块:spring-core
报错示例:
你可能是程序包org.springframework.cglib.core
或者org.springframework.cglib.proxy
中的类找不到符号
,比如org/springframework/cglib/proxy/MethodProxy.java
文件报错,如下图:
也可能是程序包org.springframework.objenesis
中的类找不到符号,又或者是org/springframework/objenesis/SpringObjenesis.java
文件报错,如下图:
报错原因:
你也可以选择看这篇摘抄,也可以直接读源码中的文件
https://www.cnblogs.com/zaid/articles/11147818.html
解决方案:
- 但是我们又遇到新的问题
JAVA_HOME is not set and no 'java' command could be found in your PATH.
- 又遇到一个问题,执行gradlew就开始下载gradle,参考博客:gradlew和gradle的区别,以下是我个人的解决步骤:
- 1.把之前下载的gradle-5.5-bin.zip压缩包拷贝到项目的gradle/wrapper目录下。
cp ~/下载/gradle-5.5-bin.zip gradle/wrapper
2.修改spring-framework/gradle/wrapper/gradle-wrapper.properties中的
distributionUrl=gradle-5.5-bin.zip
,如下图:
3.再次执行
./gradlew :spring-oxm:compileTestJava
(注意:你们输入是用英文:
代替我这里输入的中文冒号:
)
问题8:AspectJ编译问题
报错模块:spring-aspects
报错示例:
报错文件org/springframework/transaction/aspectj/AspectjTransactionManagementConfiguration.java
,找不到类AnnotationTransactionAspect
,如下图
解决方案
cd ~/下载/
source /etc/profile
java -jar aspectj-1.9.4.jar
然后就打开了一个安装交互界面,我全点的Next,最后完成时有推荐去做的事,如下图(我们在4.配置环境变量中完成)
- 4.为spring-apspect工程添加Facets属性
- 4.1 打开File -> Project Structure..
4.5 更改编译器:
搜索Java Compiler,切换Use Compiler由Java
到Ajc
,Path to Ajc Compiler填写/home/zaid/aspectj1.9/aspectjtools.jar
,选中Delegate to Javac
四、新建测试Module
- File->New Module..
- Gradle->Java
- 作为spring的module,并随便取个artifactId,比如helloworld
- 打开helloworld/build.gradle,添加依赖工程
- 在helloworld/src/main/java下创建第一个Java类MyTestBean
- 右击helloword/src/main/resources->New->XML Configuration File->Spring Config
- 编辑helloword/src/main/resources/beanFactoryTest.xml
- 在helloword/src/test/java创建BeanFactoryTest
public class BeanFactoryTest {
@Test
public void testSimpleLoad() {
BeanFactory bf = new XmlBeanFactory(new ClassPathResource("beanFactoryTest.xml"));
MyTestBean bean = (MyTestBean) bf.getBean("myTestBean");
assertEquals("testStr", bean.getTestStr());
}
}
总结
至此,我们成功的在Ubuntu上搭建了Spring源码的测试环境,并且可以Debug跟踪源码了。之后会深入分析Spring源码,写出自己的感悟心得,有兴趣的朋友,咱们一起加油