服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - Spring Boot Maven插件使用详解

Spring Boot Maven插件使用详解

2021-01-28 12:37素文宅 Java教程

这篇文章主要为大家详细介绍了Spring Boot Maven插件使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

Spring Boot Maven插件提供了使用Spring Boot应用程序步骤如下:

重新打包:创建一个可自动执行的jar或war文件。它可以替换常规工件,或者可以使用单独的分类器附加到构建生命周期。
运行:运行您的Spring引导应用程序与几个选项传递参数。
启动和停止:将Spring Boot应用程序集成到集成测试阶段,以便应用程序在其之前启动。
构建信息:生成可由致动器使用的构建信息。

重新打包一个应用程序

为了重新打包应用程序,只需要在pom.xml中添加对插件的引用,具体配置如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<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-ClassStart-Class条目,因此如果默认值不起作用,则必须配置它们(不在jar插件中)。主类实际上是由引导插件的布局属性控制的,实例:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<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应用程序的生命周期在集成测试中得到妥善管理,可以使用如下所述的启动和终止:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<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>

还可以配置更高级的设置,以便在设置特定属性时跳过集成测试:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
<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,那么集成测试将被完全跳过。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.yoodb.com/yoodb/article/detail/1420

延伸 · 阅读

精彩推荐