1. 程式人生 > 程式設計 >詳解Maven多模組打包遇到的問題解決方法

詳解Maven多模組打包遇到的問題解決方法

專案描述: springboot+springcloud+zookeeper+eureka+maven;為多模組多module的分散式架構;

專案目錄結構如下

這裡寫圖片描述

父工程為server工程,其中有多個子module工程:
1、獨立子工程:db、model、quartz、redis、util、basecontroller;
2、獨立功能模組:dao、service、controller;
其中dao、service、controller分別依賴db、model、quartz、redis、util、baseController,具體依賴關係如下圖所示:

這裡寫圖片描述

問題描述: 在使用maven打包時打包報錯;

報錯描述:

[WARNING] The requested profile "dev" could not be activated because it does not exist.
[ERROR] Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:1.5.13.RELEASE:repackage (default) on project axis-login-dao: Execution default of goal org.springframework.boot:spring-boot-maven-plugin:1.5

.13.RELEASE:repackage failed: Unable to find main class -> [Help 1]
[ERROR]
[ERROR] To see the full stack trace of the errors,re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR]
[ERROR] For more information about the errors and possible solutions,please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/PluginExecutionException

解決方案:該報錯為找不到mainclass錯誤:有人說直接在maven外掛中加上mainclass就好了,可是我打的是dao層的包,他就是一個jar,不是一個可執行程式,所以問題出在哪呢?請接著往下看:下面會報出程式包不存在的問題;

[INFO] Compiling 5 source files to D:\-server\-dao\target\classes
[INFO] -------------------------------------------------------------
[ERROR] COMPILATION ERROR :
[INFO] -------------------------------------------------------------
[ERROR] /D:/-server/-login-dao/src/main/java/com//system/dao/RoleDaoMapper.java:[3,33] 程式包com.ccx.axis.system.model不存在
[ERROR] /D:/-server/login-dao/src/main/java/com//system/dao/RoleDaoMapper.java:[4,33] 程式包com..system.model不存在

這個問題困擾了我兩天,本身不太瞭解maven,所以趁著這個機會多瞭解了一下;如果你也遇到了類似的問題,而且你也不懂maven構建的生命週期,那麼你要先去學習一下他,重要的事情說三遍:maven構建的生命週期!maven構建的生命週期!maven構建的生命週期!(這有連結 :https://www.jb51.net/article/127429.htm)
然後再過來看這個問題:我再父類的pom.xml 中添加了maven構建的外掛:

<plugins>
      <!--建立專案時自帶的 -->
      <plugin>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-maven-plugin</artifactId>
      </plugin>
      <!-- 自己新增的 -->
      <plugin>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-maven-plugin</artifactId>
        <version>1.5.13.RELEASE</version>
        <executions>
          <execution>
            <goals>
              <goal>repackage</goal>
            </goals>
          </execution>
        </executions>
      </plugin>
    </plugins>

根據網上的資料,找不到程式包的問題主要是在maven依賴相關的,我把所有的maven依賴都屢清楚了,可是還是構建不成功,這個時候就需要一些騷操作了,比如在打包我的登入模組的時候,你不能一個個的從底層網上面打包,你需要一次性把包打好了:

首先看父類的pom.xml依賴關係:

這裡寫圖片描述

* 以下為重點!!!!!*
首先要注意的是util、redis、model、db是獨立的module,login-dao、login-service 都依賴那幾個獨立的module,login-controller自帶啟動類,可以執行(需要依賴以上幾個module),login-controller的pom中需要新增啟動類(不然會報找不到主類(mainClass)錯誤);

這裡寫圖片描述

這是前期的準備工作,在準備完成後,直接對父類進行maven的構建操作:先clean 在install;

這裡寫圖片描述

最後完美解決問題!!!

另外這裡寫幾個多module專案maven構建時候需要注意的問題:

1、如果你的專案中有jsp,那麼你不能打jar包,需要打war包,因為打jar包會找不到jsp資源;

2、如果你的專案都是純後臺的程式碼,那麼父類的pom對應的packaging為pom,子類的pom的packaging為jar

<groupId>com.ccx</groupId>
  <artifactId>ccx-XXX-server</artifactId>
  <version>1.0-SNAPSHOT</version>
  <!-- 父project的pom檔案:不是jar,是pom-->
  <packaging>pom</packaging>
<groupId>com.ccx</groupId>
  <artifactId>ccx-XXX-server</artifactId>
  <version>1.0-SNAPSHOT</version>
  <!-- 父project的pom檔案:不是jar,是pom-->
  <packaging>pom</packaging>

3、不要把所有的jar包的依賴都新增到父類的pom.xml檔案中;因為你在對子類工程進行打包的時候,maven會把父類pom.xml中所有的jar包都打到子類的jar包中,這樣就多打了n遍不需要的jar包,所以,一個module需要哪個jar包就將這個jar包放到對應的module中,不要一股腦全部放在父工程的pom.xml中;

4、注意jdk、maven和springboot的版本,我本地jdk1.8,springboot1.5.13、maven3.6,環境要一直,打包才不會出現錯誤。

5、對於上面出現的maven打包報錯的問題,我有兩點思考:

專案現狀:專案所有的jar包依賴都新增到了父類的pom中,正常來講,父類pom中僅僅規定版本號問題,不應該將jar包新增到父類的pom中;另外,正常情況下打包也應該是先打底層的包,在打上層的包,對於我目前的專案現狀來說,最底層打一次包,父pom中所有的jar包都會被打進去,再網上一層打包的時候,父pom中的所有jar包又會被打一遍,而且還包括最底層的那個module,所以就會出問題,肯定打包不成功;

正確的方法應該是:父類pom中規定好依賴jar包的版本號(僅限於版本資訊);子類module依賴哪個jar包就將這個jar包新增到該子類module的pom檔案中;打包時候從最底層的開始打,然後一層層網上打包;這樣就應該不會出現我這個問題了。

我覺得以上兩點才是最重要的,如有錯誤,請指正,and歡迎交流

到此這篇關於詳解Maven多模組打包遇到的問題解決方法的文章就介紹到這了,更多相關Maven多模組打包內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!