Spring Boot Maven插件使用詳解
Spring Boot Maven插件提供了使用Spring Boot應(yīng)用程序步驟如下:
重新打包:創(chuàng)建一個可自動執(zhí)行的jar或war文件。它可以替換常規(guī)工件,或者可以使用單獨(dú)的分類器附加到構(gòu)建生命周期。
運(yùn)行:運(yùn)行您的Spring引導(dǎo)應(yīng)用程序與幾個選項傳遞參數(shù)。
啟動和停止:將Spring Boot應(yīng)用程序集成到集成測試階段,以便應(yīng)用程序在其之前啟動。
構(gòu)建信息:生成可由致動器使用的構(gòu)建信息。
重新打包一個應(yīng)用程序
為了重新打包應(yīng)用程序,只需要在pom.xml中添加對插件的引用,具體配置如下:
<build>
...
<plugins>
...
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>1.5.6.RELEASE</version>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
...
</plugins>
...
</build>
重新打包在Maven生命周期的包階段中構(gòu)建的jar或war,包括在項目中定義的任何提供的依賴關(guān)系。
默認(rèn)情況下會自動排除Devtools(您可以使用excludeDevtools屬性來控制)。為了使這些工作與war包裝相匹配,“spring-boot-devtools”依賴關(guān)系必須設(shè)置為可選的或提供的范圍。原始(即非可執(zhí)行)文件默認(rèn)情況下重命名為.original,但也可以使用自定義分類器保留原始工件。
Spring Boot Maven插件會重寫配置,特別是它管理Main-Class和Start-Class條目,因此如果默認(rèn)值不起作用,則必須配置它們(不在jar插件中)。主類實際上是由引導(dǎo)插件的布局屬性控制的,實例:
<build>
...
<plugins>
...
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>1.5.6.RELEASE</version>
<configuration>
<mainClass>${start-class}</mainClass>
<layout>ZIP</layout>
</configuration>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
...
</plugins>
...
</build>
該布局屬性基歸檔類型((jar或者war)。可以在以下布局中使用:
JAR:常規(guī)可執(zhí)行JAR布局。
WAR:可執(zhí)行WAR布局。提供的依賴關(guān)系放置在WEB-INF/lib中,以避免戰(zhàn)爭部署在servlet容器中時發(fā)生沖突。
ZIP(DIR的別名):類似于使用PropertiesLauncher的JAR布局。
MODULE:捆綁依賴(不包括提供的范圍)和項目資源,不捆綁引導(dǎo)加載程序。
NONE:捆綁所有依賴項和資源,不捆綁引導(dǎo)加載程序。
運(yùn)行應(yīng)用程序
Spring Boot Maven插件可以用于從命令行啟動應(yīng)用程序,具體執(zhí)行命令如下:
mvn spring-boot:run
默認(rèn)情況下,該應(yīng)用程序直接從Maven JVM執(zhí)行。如果需要在分叉進(jìn)程中運(yùn)行,可以使用'fork'選項。如果指定了'jvmArguments'或'agent'選項,或者如果存在devtools,則也會發(fā)生分岔。
如果需要指定一些JVM參數(shù)(即用于調(diào)試目的),可以使用jvmArguments參數(shù)。為方便起見,要啟用的配置文件由特定屬性(配置文件)處理。
使用集成測試
為了確保Spring Boot應(yīng)用程序的生命周期在集成測試中得到妥善管理,可以使用如下所述的啟動和終止:
<build>
...
<plugins>
...
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>1.5.6.RELEASE</version>
<executions>
<execution>
<id>pre-integration-test</id>
<goals>
<goal>start</goal>
</goals>
</execution>
<execution>
<id>post-integration-test</id>
<goals>
<goal>stop</goal>
</goals>
</execution>
</executions>
</plugin>
...
</plugins>
...
</build>
還可以配置更高級的設(shè)置,以便在設(shè)置特定屬性時跳過集成測試:
<properties>
<it.skip>false</it.skip>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-failsafe-plugin</artifactId>
<configuration>
<skip>${it.skip}</skip>
</configuration>
</plugin>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>1.5.6.RELEASE</version>
<executions>
<execution>
<id>pre-integration-test</id>
<goals>
<goal>start</goal>
</goals>
<configuration>
<skip>${it.skip}</skip>
</configuration>
</execution>
<execution>
<id>post-integration-test</id>
<goals>
<goal>stop</goal>
</goals>
<configuration>
<skip>${it.skip}</skip>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
注意:如果運(yùn)行mvn verify -Dit.skip=true,那么集成測試將被完全跳過。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Spring-data-redis操作redis cluster的示例代碼
這篇文章主要介紹了Spring-data-redis操作redis cluster的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10
詳解Spring Cloud負(fù)載均衡重要組件Ribbon中重要類的用法
本篇文章主要介紹了詳解Spring Cloud負(fù)載均衡重要組件Ribbon中重要類的用法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-03-03
SpringMVC 重新定向redirect請求中攜帶數(shù)據(jù)方式
這篇文章主要介紹了SpringMVC 重新定向redirect請求中攜帶數(shù)據(jù)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12

