Maven(二) 構建生命週期
構建生命週期
Maven的生命週期(lifecycle)可以理解為由Maven的各種plugin按照一定的順序執行來完成java專案清理、編譯、打包、測試、佈署等整個專案的流程的一個過程。
Maven內建了各種外掛,如果再pom中沒有顯示配置就會呼叫預設的內建外掛,如果pom中配置了就會呼叫配置的外掛。
1. Maven生命週期外掛配置-build
build標籤描述瞭如何編譯及打包專案,具體的編譯和打包工作是通過其中的plugin配置來實現的。
plugin不是必須的,即使不新增預設也會引入以下外掛:
外掛 | 功能 |
---|---|
maven-clean-plugin | 清理上一次執行建立的目標檔案 |
maven-resources-plugin | 清理上一次執行建立的目標檔案 |
maven-compiler-plugin | 編譯原始檔和測試原始檔 |
maven-surefire-plugin | 執行測試檔案 |
maven-jar-plugin | 建立 jar |
maven-install-plugin | 安裝 jar,將建立生成的 jar 拷貝到 .m2/repository 下面 |
maven-deploy-plugin | 釋出 jar |
如果有需要可以針對各個 plugin 進行特殊配置,需要在pom.xml中的<plugins>
標籤中顯示指定plugin 和 屬性配置。
1.1 <resource>
元素
資源往往不是程式碼,而是properties或xml檔案,無需編譯,構建過程中往往會將資原始檔從源路徑複製到指定的目標路徑。
resources則給出各個資源在maven專案中的具體路徑。
<build> <resources> <resource> <!--資原始檔源路徑,預設位於src/main/resources/目錄下--> <directory>src/main/java</directory> <!--一組檔名的匹配模式,被匹配的資原始檔將被構建過程處理,相反的有excludes--> <includes> <include>**/*.xml</include> <include>**/*.ftl</include> </includes> <!-- 排除內容(編譯時不復制指定排除的內容) --> <excludes> <exclude>*.txt</exclude> </excludes> <!-- 輸出目錄(預設為${build.outputDirectory},即target/classes) --> <targetPath>${build.outputDirectory}</targetPath> </resource> <resource> <directory>src/main/resources</directory> <includes> <include>**/*</include> </includes> </resource> </resources> </build>
1.2 <plugins>
元素
設定構建過程中需要的外掛。
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<!--該外掛所需要的特殊配置,在父子專案之間可以覆蓋或合併-->
<configuration>
<encoding>${charset}</encoding>
<target>${jdk.version}</target>
<source>${jdk.version}</source>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<!--該外掛的某個goal的執行方式-->
<executions>
<execution>
<!--外掛的goal要嵌入到Maven的phase中執行,如verify-->
<phase>package</phase>
<!--要執行的外掛的goal,如run-->
<goals>
<goal>jar</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
2. 常用外掛
2.1 maven-clean-plugin
清理構建目錄下的全部內容,構建目錄預設是target,可配置。
2.2 maven-resources-plugin
負責處理專案資原始檔並拷貝到輸出目錄。分為main resources和test resources。
結合<build>
下的<resources>
標籤可配置資原始檔路徑。
2.3 maven-compiler-plugin
編譯Java程式碼。
預設會用maven-compiler-plugin
預設的jdk
版本來進行處理,這樣就容易出現版本不匹配。一般我們需要指定編譯版本。
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<encoding>UTF-8</encoding>
<target>1.8</target>
<source>1.8</source>
</configuration>
</plugin>
</plugins>
</build>
2.4 maven-surefire-plugin
執行測試用例的外掛,不顯示配置就會用預設配置。可設定跳過測試。
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<skipTests>true</skipTests>
</configuration>
</plugin>
</plugins>
</build>
2.5 maven-jar-plugin
把class檔案、配置檔案打成一個jar(war或其它格式)包。
注意:依賴包是不在jar裡面的,需要建立lib目錄,且jar和lib目錄在同級目錄。
SpringBoot專案,一般使用spring-boot-maven-plugin
外掛進行打包,直接打成一個可執行的jar包。
2.6 maven-install-plugin
將打包生成的jar檔案安裝到本地倉庫。
2.7 maven-deploy-plugin
將打包生成的jar檔案部署到POM配置的遠端庫中。
2.8 maven-source-plugin
將原始碼(.java檔案)打成Jar包。
配置:
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>jar</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
2.9 spring-boot-maven-plugin
一般的maven專案的打包命令,不會把依賴的jar包也打包進去的,只是會放在jar包的同目錄下,能夠引用就可以了。
但是spring-boot-maven-plugin
外掛,會將依賴的jar包全部打包進去,生成一個可直接執行的jar。
需顯式配置。
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<!--指定預設執行類-->
<mainClass>com.aster.netsales.poss.openapi.PossOpenapiApplication</mainClass>
</configuration>
</plugin>
</plugins>
</build>