Spring Boot Maven Plugin 总结一下下!
- 初识Spring Boot Maven Plugin
- 自定义属性、默认值以及在命令行上SpringBoot开头的命令上覆盖属性
- Spring Boot Maven Plugin打包的一些配置。
- Spring Boot Maven Plugin对包中的内容进行layers-分层。
- 还没发,去下面扫描关注公众号看吧。
上面只玩了SpringBoot:repackage的一些东西,其实还有很多没玩。比如:
- spring-boot:start
- spring-boot:stop
- spring-boot:help
- spring-boot:build-info
- mvn spring-boot:build-image
- spring-boot:run
spring-boot:repackage,默认goal。在mvn package之后,再次打包可执行的jar/war,同时保留mvn package生成的jar/war为.origin
spring-boot:run,运行Spring Boot应用
spring-boot:start,在mvn integration-test阶段,进行Spring Boot应用生命周期的管理
spring-boot:stop,在mvn integration-test阶段,进行Spring Boot应用生命周期的管理
spring-boot:build-info,生成Actuator使用的构建信息文件build-info.properties
打镜像以后会补充上,不过要到系统学完docker以后再说了。
下面是翻译的文档,大致扫了一眼,可以直接去官方文档学习,我就留个备份。
https://docs.spring.io/spring-boot/docs/2.5.x/maven-plugin/reference/htmlsingle/#introduction
使用Maven运行您的应用程序
该插件包括一个运行目标,可用于从命令行启动您的应用程序,如以下示例所示:
$ mvn spring-boot:run
可以使用arguments参数指定应用程序参数,还明确支持系统属性和环境变量。
如果需要指定一些JVM参数(即出于调试目的),则可以使用该jvmArguments参数
默认情况下,应用程序是在分支过程中执行的,并且在命令行上设置属性不会影响该应用程序。
由于启用配置文件非常普遍,因此有一个专用的profiles属性可为其提供快捷方式-Dspring-boot.run.jvmArguments="-Dspring.profiles.active=dev"
尽管不建议这样做,但是可以通过禁用该fork属性直接从Maven JVM执行应用程序。这样做意味着的jvmArguments,systemPropertyVariables,environmentVariables和agents选项都将被忽略。
在devtools运行时,它会在重新编译应用程序时检测到更改并自动刷新它。这不仅适用于资源,而且适用于代码。它还提供了LiveReload服务器,以便它可以在发生任何变化时自动触发浏览器刷新。
还可以将Devtools配置为仅在静态资源发生更改时刷新浏览器(并忽略代码中的任何更改)。只需在您的项目中包含以下属性:
spring.devtools.remote.restart.enabled=false
在此之前devtools,该插件默认情况下支持资源的热刷新,现在已禁用它,以支持上述解决方案。您可以随时通过配置项目来还原它:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<addResources>true</addResources>
</configuration>
</plugin>
</plugins>
</build>
当addResources启用时,任何src/main/resources当你运行应用程序,并在任何重复found目录将被添加到应用程序类路径target/classes将被删除。这样可以热刷新资源,这在开发Web应用程序时非常有用。例如,您可以处理HTML,CSS或JavaScript文件,并且无需重新编译应用程序即可立即查看更改。这也是允许您的前端开发人员工作而无需下载和安装Java IDE的一种有用方法。
使用此功能的副作用是在构建时无法进行资源过滤。
为了与repackage目标保持一致,目标run以这样的方式构建类路径:插件配置中排除的任何依赖项也将从类路径中排除。
有时在运行应用程序时包含测试依赖项很有用。例如,如果要在使用存根类的测试模式下运行应用程序。如果您希望这样做,可以将useTestClasspath参数设置为true。
这仅在运行应用程序时适用:repackage目标不会将测试依赖项添加到生成的JAR / WAR中。
spring-boot:run
org.springframework.boot:spring-boot-maven-plugin:2.5.0-RC1
在适当位置运行应用程序。
必填参数
classesDirectory File ${project.build.outputDirectory}
包含应打包到归档文件中的类和资源文件的目录。
可选参数
addResources boolean false
直接将Maven资源添加到类路径,这允许实时就地编辑资源。target/classes如果ClassLoader.getResources()调用了重复资源,则会阻止重复的资源出现两次。请考虑添加spring-boot-devtools到您的项目中,因为它提供了此功能以及更多其他功能。
属性 spring-boot.run.addResources
agents File[]
代理包的路径。注意:要使用此功能,需要进行分叉的过程。属性 spring-boot.run.agents
arguments String[]
应该传递给应用程序的参数。
commandlineArguments String
命令行中应传递给应用程序的参数。使用空格分隔多个参数,并确保在引号之间包含多个值。指定后,优先于#arguments。属性 spring-boot.run.arguments
directories String[]
除了类目录之外的其他目录,应添加到类路径中。属性spring-boot.run.directories
environmentVariables Map
应与用于运行应用程序的分叉进程相关联的环境变量列表。注意:要使用此功能,需要进行分叉的过程。
excludeGroupIds String
用逗号分隔的要排除的groupId名称列表(完全匹配)。属性 spring-boot.excludeGroupIds
excludes List
要排除的artifact定义的集合。该Exclude元素定义强制性groupId和artifactId性质和可选classifier性。属性spring-boot.excludes
fork boolean true
指示是否应分叉运行进程的标志。禁用分叉将禁用某些功能,例如代理,自定义JVM参数,devtools或指定要使用的工作目录。属性 spring-boot.run.fork
includes List
要包括的artifact定义的集合。该Include元素定义强制性groupId和artifactId性质以及可选的强制性groupId和artifactId性质和可选classifier性。属性spring-boot.includes
jvmArguments String
应该与用于运行应用程序的分叉进程相关联的JVM参数。在命令行上,请确保在引号之间包含多个值。注意:要使用此功能,需要进行分叉的过程。属性 spring-boot.run.jvmArguments
mainClass String
主类的名称。如果未指定,将使用找到的第一个包含“ main”方法的编译类。属性 spring-boot.run.main-class
noverify boolean
标记为该代理需要-noverify。属性spring-boot.run.noverify
optimizedLaunch boolean true
是否应该优化JVM的启动。属性 spring-boot.run.optimizedLaunch
profiles String[]
弹簧轮廓激活。指定“ spring.profiles.active”参数的便捷快捷方式。在命令行上使用逗号分隔多个配置文件。属性spring-boot.run.profiles
skip boolean false
跳过执行。属性spring-boot.run.skip
systemPropertyVariables Map
传递给进程的JVM系统属性列表。注意:要使用此功能,需要进行分叉的过程。
useTestClasspath Boolean false
运行时进行标记以包括测试类路径。属性spring-boot.run.useTestClasspath
workingDirectory File
该应用程序要使用的当前工作目录。如果未指定,将使用basedir。注意:要使用此功能,需要进行分叉的过程。属性spring-boot.run.workingDirectory
spring-boot:start
org.springframework.boot:spring-boot-maven-plugin:2.5.0-RC1
启动spring应用程序。与run目标相反,这不会阻止并允许其他目标在应用程序上运行。此目标通常用于集成测试方案中,在该方案中,应用程序在测试套件之前启动,然后在测试套件之后停止。
spring-boot:help
org.springframework.boot:spring-boot-maven-plugin:2.5.0-RC1
在spring-boot-maven-plugin上显示帮助信息。调用mvn spring-boot:help -Ddetail=true -Dgoal=<goal-name>以显示参数详细信息。
detail boolean false
如果为true,则显示每个目标的所有可设置属性。
用户属性detail
goal String
要显示帮助的目标的名称。如果未指定,将显示所有目标。属性 goal
indentSize int 2
每个压痕级别的空格数应为正。属性 indentSize
lineLength int 80
显示行的最大长度应为正。属性lineLength