标签:loading 依赖 install 文件名 framework 注意 依赖包 yun java
Maven的生命周期(lifecycle)可以理解为由Maven的各种plugin按照一定的顺序执行来完成java项目清理、编译、打包、测试、布署等整个项目的流程的一个过程。
Maven内置了各种插件,如果再pom中没有显示配置就会调用默认的内置插件,如果pom中配置了就会调用配置的插件。
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 和 属性配置。
<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>
<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>
清理构建目录下的全部内容,构建目录默认是target,可配置。
负责处理项目资源文件并拷贝到输出目录。分为main resources和test resources。
结合<build>
下的<resources>
标签可配置资源文件路径。
编译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>
执行测试用例的插件,不显示配置就会用默认配置。可设置跳过测试。
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<skipTests>true</skipTests>
</configuration>
</plugin>
</plugins>
</build>
把class文件、配置文件打成一个jar(war或其它格式)包。
注意:依赖包是不在jar里面的,需要建立lib目录,且jar和lib目录在同级目录。
SpringBoot项目,一般使用spring-boot-maven-plugin
插件进行打包,直接打成一个可执行的jar包。
将打包生成的jar文件安装到本地仓库。
将打包生成的jar文件部署到POM配置的远程库中。
将源码(.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>
一般的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>
标签:loading 依赖 install 文件名 framework 注意 依赖包 yun java
原文地址:https://www.cnblogs.com/lyldelove/p/13210746.html