Spark3源码编译-IDEA
之前可以在linux环境进行spark源码的修改和编译,没有在笔记本上走通过编译流程,记录遇到的问题和解决方案。在电脑上修改编译源码方便日常的调试使用,步骤如下。
注:这里使用IDEA版本是社区版-2021.1.1。
-
下载Spark3的源码,直接下载master分支代码或spark 3.1.1 tag源码zip包,解压(3.x其他版本随意)。
-
使用IDEA“Open”spark源码文件夹,等待自动识别为
Maven项目并加载完毕。 -
开始编译前,在MAVEN Profiles选择必要的模块:hadoop、hive、hive-thriftserver、kubernetes、sparkr、yarn。
-
从MAVEN窗口工程列表找到root的Spark Project Parent POM开始
clean package:编译到Spark Core模块时遇到第一个错误:Cannot run program "bash": CreateProcess error=2, 系统找不到指定的文件。这个是本地Windows环境不能执行bash导致的,需要本机安装Git工具(IDEA也可以直接安装,默认位置是C:\Program Files\Git),将这个C:\Program Files\Git\bin路径添加到系统环境变量Path中,然后重启电脑就可以解决。 -
直接按照官网提示设置
MAVEN_OPTS="-Xmx2g -XX:ReservedCodeCacheSize=1g"环境变量,会提示参数无效,无法启动JVM,忽略先继续,下一步解决。 -
继续编译遇到提示:
CodeCache is full. Compiler has been disabled.Try increasing the code cache size using -XX:ReservedCodeCacheSize=,应该是第5步不设置导致的。解决办法:
工程右上角“Add/Edit Configurations”->在弹出的"Add New Configuration"列表中选择"maven",在Runner选项卡添加虚拟机选项:-Xmx2g -XX:ReservedCodeCacheSize=1g(根据自己机器配置可以适当调增)。
-
全部编译成功。(如遇到jar下载中断、网络连接失败等依赖问题,无需理会重新clean、package即可)
-
末尾还是有警告,不过不影响编译:
CodeCache is full. Compiler has been disabled. OpenJDK 64-Bit Server VM warning: Try increasing the code cache size using -XX:ReservedCodeCacheSize=按第6步设置好后重启电脑似乎有效。