背景 看到Apache DolphinScheduler社區群有很多用戶反饋和討論這塊問題,針對不相容的問題,不僅需要自己重新編譯各一個新包,而且因為預設是使用zk-3.8的配置,所以會出現不相容問題。使用zk-3.4配置即可適配3.4.x 解決辦法(一) 切換到項目源碼的根路徑中執行 mvn cl ...
背景
看到Apache DolphinScheduler社區群有很多用戶反饋和討論這塊問題,針對不相容的問題,不僅需要自己重新編譯各一個新包,而且因為預設是使用zk-3.8的配置,所以會出現不相容問題。使用zk-3.4配置即可適配3.4.x
解決辦法(一)
切換到項目源碼的根路徑中執行
mvn clean package -T 1C -Prelease '-Dmaven.test.skip=true' '-Dcheckstyle.skip=true' '-Dmaven.javadoc.skip=true' '-Dzk-3.4'
上述命令解釋
mvn clean package 依次執行了clean、resources、compile、testResources、testCompile、test、jar(打包)等7個階段。
指定多線程編譯,可以增加~
拓展
-Dmaven.compile.fork=true 表示開啟多線程
mvn -T 4 install -- will use 4 threads
mvn -T 1C install -- will use 1 thread per available CPU core
mvn clean package -T 1C -Dmaven.compile.fork=true
-Prelease 是 Maven Release Plugin 的配置
Maven中-DskipTests和-Dmaven.test.skip=true的區別
在使用mvn package進行編譯、打包時,Maven會執行src/test/java中的JUnit測試用例,有時為了編譯過程中跳過測試步驟,會使用參數-DskipTests和-Dmaven.test.skip=true,這兩個參數的主要區別是:
-DskipTests,不執行測試用例,但編譯測試用例類生成相應的class文件至target/test-classes下。
-Dmaven.test.skip=true,不執行測試用例,也不編譯測試用例類。
-D參數
如果參數不存在於 pom.xml 文件中,它將被設置。如果參數已經存在 pom.xml 文件中,其值將被作為參數傳遞的值覆蓋。
解決辦法(二)
修改源碼中的pom.xml配置文件
1、從github下載源碼
直接訪問https://github.com/,登陸之後搜索Apache DolphinScheduler!
在百度直接搜:
官網網址:
https://github.com/apache/dolphinscheduler
選擇 release版本
2、將下載好的zip包解壓出來,並導入IDEA工具中
3、修改maven和jdk配置
4、MVN命令操作
根目錄執行
mvn clean package -T 1C -Prelease '-Dmaven.test.skip=true' '-Dcheckstyle.skip=true' '-Dmaven.javadoc.skip=true' '-Dzk-3.4'
報錯如下
Failed to execute goal com.diffplug.spotless:spotless-maven-plugin:2.27.2:check (default) on project dolphinscheduler: The following files had format violations:
這個是問題沒有因為沒有格式化代碼,所以在校驗的時候不通過
根據上面的提示只需要執行下命令:mvn spotless:apply
就可以了
隨後會刷屏,過一會就會出現如下圖,完事了
再次根目錄執行
mvn clean package -T 1C -Prelease '-Dmaven.test.skip=true' '-Dcheckstyle.skip=true' '-Dmaven.javadoc.skip=true' '-Dzk-3.4'
報錯如下
從提示中可以看出來,com.github.eirslett:frontend-maven-plugin
這個插件有問題
首先看看本地的maven倉庫中,有沒有把這個插件通過依賴下載出來
在d:\IdeaProjects\dolphinscheduler-3.2.0-release\dolphinscheduler-ui\pom.xml文件中
把
再次根目錄執行
mvn clean package -T 1C -Prelease '-Dmaven.test.skip=true' '-Dcheckstyle.skip=true' '-Dmaven.javadoc.skip=true' '-Dzk-3.4'
可以看到,已經編譯成功了。找到打好包生成的目標文件,位置是:項目源碼目錄\dolphinscheduler-dist\target
我的位置是 D:\IdeaProjects\dolphinscheduler-3.2.0-release\dolphinscheduler-dist\target
5、修改源碼中的依賴配置
我不知道配置文件的指定的位置,在IDEA開發工具中按ctrl+shift+f組合鍵, 在項目所有文件中搜索:zookeeper.version
在d:\\IdeaProjects\\dolphinscheduler-3.2.0-release\\dolphinscheduler-bom\\pom.xml
文件中找到
修改一下源碼,修改後如下圖所示
根目錄執行
mvn clean package -T 1C -Prelease '-Dmaven.test.skip=true' '-Dcheckstyle.skip=true' '-Dmaven.javadoc.skip=true'
可以看到,已經編譯成功了。希望本文能幫助更多用戶解決問題,如果您對這個話題感興趣,歡迎來社區交流!
本文由 白鯨開源 提供發佈支持!