Spring Boot Maven插件使用详解
spring boot maven插件提供了使用spring boot应用程序步骤如下:
重新打包:创建一个可自动执行的jar或war文件。它可以替换常规工件,或者可以使用单独的分类器附加到构建生命周期。
运行:运行您的spring引导应用程序与几个选项传递参数。
启动和停止:将spring boot应用程序集成到集成测试阶段,以便应用程序在其之前启动。
构建信息:生成可由致动器使用的构建信息。
重新打包一个应用程序
为了重新打包应用程序,只需要在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生命周期的包阶段中构建的jar或war,包括在项目中定义的任何提供的依赖关系。
默认情况下会自动排除devtools(您可以使用excludedevtools属性来控制)。为了使这些工作与war包装相匹配,“spring-boot-devtools”依赖关系必须设置为可选的或提供的范围。原始(即非可执行)文件默认情况下重命名为.original,但也可以使用自定义分类器保留原始工件。
spring boot maven插件会重写配置,特别是它管理main-class和start-class条目,因此如果默认值不起作用,则必须配置它们(不在jar插件中)。主类实际上是由引导插件的布局属性控制的,实例:
<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:常规可执行jar布局。
war:可执行war布局。提供的依赖关系放置在web-inf/lib中,以避免战争部署在servlet容器中时发生冲突。
zip(dir的别名):类似于使用propertieslauncher的jar布局。
module:捆绑依赖(不包括提供的范围)和项目资源,不捆绑引导加载程序。
none:捆绑所有依赖项和资源,不捆绑引导加载程序。
运行应用程序
spring boot maven插件可以用于从命令行启动应用程序,具体执行命令如下:
mvn spring-boot:run
默认情况下,该应用程序直接从maven jvm执行。如果需要在分叉进程中运行,可以使用'fork'选项。如果指定了'jvmarguments'或'agent'选项,或者如果存在devtools,则也会发生分岔。
如果需要指定一些jvm参数(即用于调试目的),可以使用jvmarguments参数。为方便起见,要启用的配置文件由特定属性(配置文件)处理。
使用集成测试
为了确保spring boot应用程序的生命周期在集成测试中得到妥善管理,可以使用如下所述的启动和终止:
<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>
还可以配置更高级的设置,以便在设置特定属性时跳过集成测试:
<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>
注意:如果运行mvn verify -dit.skip=true,那么集成测试将被完全跳过。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: GridView使用学习总结
推荐阅读