背景
看到Apache DolphinScheduler社區(qū)群有很多用戶反饋和討論這塊問題,針對不兼容的問題,不僅需要自己重新編譯各一個新包,而且因為默認(rèn)是使用zk-3.8的配置,所以會出現(xiàn)不兼容問題。使用zk-3.4配置即可適配3.4.x
解決辦法(一)
切換到項目源碼的根路徑中執(zhí)行
mvn clean package -T 1C -Prelease '-Dmaven.test.skip=true' '-Dcheckstyle.skip=true' '-Dmaven.javadoc.skip=true' '-Dzk-3.4'
上述命令解釋
mvn clean package ?依次執(zhí)行了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的區(qū)別
在使用mvn package進(jìn)行編譯、打包時,Maven會執(zhí)行src/test/java中的JUnit測試用例,有時為了編譯過程中跳過測試步驟,會使用參數(shù)-DskipTests和-Dmaven.test.skip=true,這兩個參數(shù)的主要區(qū)別是:
-DskipTests,不執(zhí)行測試用例,但編譯測試用例類生成相應(yīng)的class文件至target/test-classes下。
-Dmaven.test.skip=true,不執(zhí)行測試用例,也不編譯測試用例類。
-D參數(shù)
如果參數(shù)不存在于 pom.xml 文件中,它將被設(shè)置。如果參數(shù)已經(jīng)存在 pom.xml 文件中,其值將被作為參數(shù)傳遞的值覆蓋。
解決辦法(二)
修改源碼中的pom.xml配置文件
1、從github下載源碼
直接訪問https://github.com/,登陸之后搜索Apache DolphinScheduler!
在百度直接搜:
官網(wǎng)網(wǎng)址:
https://github.com/apache/dolphinscheduler
選擇 release版本
2、將下載好的zip包解壓出來,并導(dǎo)入IDEA工具中
3、修改maven和jdk配置
4、MVN命令操作
根目錄執(zhí)行
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:
這個是問題沒有因為沒有格式化代碼,所以在校驗的時候不通過
根據(jù)上面的提示只需要執(zhí)行下命令:mvn spotless:apply?
就可以了
隨后會刷屏,過一會就會出現(xiàn)如下圖,完事了
再次根目錄執(zhí)行
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文件中
把
再次根目錄執(zhí)行
mvn clean package -T 1C -Prelease '-Dmaven.test.skip=true' '-Dcheckstyle.skip=true' '-Dmaven.javadoc.skip=true' '-Dzk-3.4'
可以看到,已經(jīng)編譯成功了。找到打好包生成的目標(biāo)文件,位置是:項目源碼目錄\dolphinscheduler-dist\target
我的位置是 D:\IdeaProjects\dolphinscheduler-3.2.0-release\dolphinscheduler-dist\target
5、修改源碼中的依賴配置
我不知道配置文件的指定的位置,在IDEA開發(fā)工具中按ctrl+shift+f組合鍵, 在項目所有文件中搜索:zookeeper.version
在d:\\IdeaProjects\\dolphinscheduler-3.2.0-release\\dolphinscheduler-bom\\pom.xml
文件中找到
修改一下源碼,修改后如下圖所示
根目錄執(zhí)行
mvn clean package -T 1C -Prelease '-Dmaven.test.skip=true' '-Dcheckstyle.skip=true' '-Dmaven.javadoc.skip=true'
可以看到,已經(jīng)編譯成功了。希望本文能幫助更多用戶解決問題,如果您對這個話題感興趣,歡迎來社區(qū)交流!文章來源:http://www.zghlxwxcb.cn/news/detail-825431.html
本文由 白鯨開源 提供發(fā)布支持!文章來源地址http://www.zghlxwxcb.cn/news/detail-825431.html
到了這里,關(guān)于Apache DolphinScheduler中ZooKeeperCDH不兼容問題的解決方案的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!