【Maven】打包插件使用详解

这篇具有很好参考价值的文章主要介绍了【Maven】打包插件使用详解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本文参照官网:http://maven.apache.org/plugins

一.常用Maven打包插件:

1.spring-boot-maven-plugin:这个插件是springboot的maven插件,能够将springboot项目打包为可执行的jar/war,官网文档。
2.maven-assembly-plugin: 这个插件是maven结构定制化的打包,maven中针对打包任务而提供的标准插件,包含了以下几个插件的功能,官网文档。
3.maven-shade-plugin:这个插件是把整个项目(包含它的依赖)都打包到一个可以执行的jar包中,官网文档。
4.maven-jar-plugin:这个插件是将指定包目录打成单独的jar包,可以配置需要打包进去的文件,程序的入口类等,官网文档。
5.maven-resources-plugin:这个插件是用来处理,拷贝resources下的资源文件,官网文档。
6.maven-compiler-plugin:这个插件是用来编译Java代码,官网文档。
7.maven-dependency-plugin:这个插件是用来拷贝依赖库,官网文档。

二.使用以及说明:

1.spring-boot-maven-plugin

// An highlighted block
	<plugin>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-maven-plugin</artifactId>
     <version>2.1.1.RELEASE</version>
     <configuration>
     	 <!-- 配置使devtools生效 -->
         <fork>true</fork> 
         <!-- 配置为 true,打包出来的 jar/war 就是可执行的,可以配置为linux的service启动,如果使用 jar -xf 等解压命令,将此配置改为false-->
         <executable>true</executable>
         <!-- 配置在使用第三方的jar包作为依赖,打包时,指定maven把scope为system的依赖同样打到jar包中去,需要配合dependency的<scope>system</scope><systemPath>${project.basedir}/libs/xxx-api-sdk-1.1.0.jar</systemPath>使用-->
         <includeSystemScope>true</includeSystemScope>
     </configuration>
     <executions>
         <execution>
             <goals>
             	 <!-- 配置在 mvn package 执行之后,再次打包生成可执行的 jar包。repackage生成jar包的名称与 mvn package 生成的原始 jar/war包名称相同,而原始 jar包被重命名为 *.origin。这样生成的*.jar可直接运行,但不能被其他项目模块依赖。这是因为repackage将项目的class都放在了jar包 BOOT-INF/classes 文件夹中,导致其他模块不能加载jar包中的 class-->
                 <goal>repackage</goal>
             </goals>
         </execution>
     </executions>
   </plugin>

spring-boot-maven-plugin提供的goals

mvn spring-boot:build-info:生成项目的构建信息文件
mvn spring-boot:help:展示spring-boot-maven-plugin的帮助信息
mvn spring-boot:repackage :可生成可执行的jar包或war包。插件的核心goal。
mvn spring-boot:run:运行 Spring Boot 应用
mvn spring-boot:start:将SpringBoot应用程序集成到集成测试阶段,在此之前启动
mvn spring-boot:stop:将SpringBoot应用程序集成到集成测试阶段,在此之前启动

2.maven-assembly-plugin

<plugin>
  			<groupId>org.apache.maven.plugins</groupId>
  			<artifactId>maven-assembly-plugin</artifactId>
  			<version>2.4<version>
  			<executions>
   				<execution>
   					<id>make-assembly</id>
   					<!-- 配置绑定到package生命周期 -->
   					<phase>package</phase>
   					<goals>
    					<!-- 配置只运行一次 -->
    					<goal>single</goal>
   					</goals>
   				</execution>
  			</executions>
  			<configuration>
   				<!-- 配置描述符文件 -->
   				<descriptor>src/main/assembly/assembly.xml</descriptor>
   				<!-- 配置可以使用Maven预配置的描述符
   				<descriptorRefs>
   					<descriptorRef>jar-with-dependencies</descriptorRef>
   				</descriptorRefs> -->
  			</configuration>
</plugin>

自定义打包的时候,需要自己写描述符文件,格式为XML:

<assembly>
	<!--配置添加到打包文件名的标识符,用来做后缀-->
 	<id>assembly</id>
 	<!--配置打包文件格式,有zip、tar、tar.gz、tar.bz2、jar、war-->
 	<formats>
 		<format>tar.gz</format>
 	</formats>
 	<!---->
 	<includeBaseDirectory>true</includeBaseDirectory>
 	<!-- 配置一组文件在打包时的属性。-->
 	<fileSets>
 		<fileSet>
 			<!-- 配置源目录的路径。-->
  			<directory>src/main/bin</directory>
  			<!-- 配置包含或排除哪些文件,支持通配符-->
  			<includes>
  				<include>*.sh</include>
  			</includes>
  			<outputDirectory>bin</outputDirectory>
  			<!-- 配置该目录下的文件属性,采用Unix八进制描述法,默认值是0644-->
  			<fileMode>0755</fileMode>
 		</fileSet>
 		<fileSet>
  			<directory>src/main/conf</directory>
  			<!-- 配置生成目录的路径。-->
  			<outputDirectory>conf</outputDirectory>
 		</fileSet>
 		<fileSet>
  			<directory>src/main/sql</directory>
  			<includes>
  				<include>*.sql</include>
  			</includes>
  			<outputDirectory>sql</outputDirectory>
 		</fileSet>
 		<fileSet>
  			<directory>target/classes/</directory>
  			<includes>
  				<include>*.properties</include>
  				<include>*.xml</include>
  				<include>*.txt</include>
  			</includes>
  			<outputDirectory>conf</outputDirectory>
 		</fileSet>
 	</fileSets>
 	<!-- 配置和fileSets大致相同,不过是指定单个文件,并且还可以通过destName属性来设置与源文件不同的名称。-->
 	<files>
 		<file>
  			<source>target/${project.artifactId}-${project.version}.jar</source>
  			<outputDirectory>.</outputDirectory>
 		</file>
 	</files>
  	<!-- 配置工程依赖文件在打包时的属性-->
 	<dependencySets>
 		<dependencySet>
 		<!--配置布尔值,false表示将依赖以原来的JAR形式打包,true则表示将依赖解成*.class文件的目录结构打包。-->
  		<unpack>false</unpack>
  		<!--配置符合哪个作用范围的依赖会被打包进去。compile与provided都不用管,一般是写runtime。 按照以上配置打包好后,将.tar.gz文件上传到服务器,解压之后就会得到bin、conf、lib等规范化的目录结构-->
  		<scope>runtime</scope>
  		<outputDirectory>lib</outputDirectory>
 		</dependencySet>
 	</dependencySets>
</assembly>

3.maven-shade-plugin

<plugin>
             <groupId>org.apache.maven.plugins</groupId>
             <artifactId>maven-shade-plugin</artifactId>
             <version>2.4.1</version>
             <executions>
                 <execution>
                 <!--配置goal-shade绑定到phase-package 上 会在 target 文件生成一个以 -shaded.jar 为后缀的 jar 包-->
                     <phase>package</phase>
                     <goals>
                        <goal>shade</goal>
                     </goals>
                     <configuration>
		              <artifactSet>
		                <excludes>
		                <!--配置该工程依赖的部分 Jar 包 include/exclude 掉。-->
		                  <exclude>classworlds:classworlds</exclude>
		                  <exclude>junit:junit</exclude>
		                </excludes>
		              </artifactSet>
		              <!--配置依赖的某个 Jar 包内部的类或者资源 include/exclude 掉。-->
		               <filters>
		                <filter>
		                  <artifact>junit:junit</artifact>
		                  <includes>
		                    <include>junit/framework/</include>
		                    <include>org/junit/</include>
				          </includes>
		                  <excludes>
		                    <exclude>org/junit/experimental/</exclude>
		                    <exclude>org/junit/runners/</exclude>
		                  </excludes>
		                </filter>
		               </filters>
		               <!--配置将所有不使用的类全部排除掉,将 jar 最小化-->
		               <minimizeJar>true</minimizeJar>
		               <!--配置 MainClass 创建一个可执行 Jar 包。-->
		                <transformers>
			                <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
			                  <mainClass>org.sonatype.haven.HavenCli</mainClass>
			                </transformer>
              			</transformers>
              			<!-- 配置解决jar或类的多版本冲突 在打包的时候把类重命名-->
              			<relocations>
			                <relocation>
			                  <pattern>org.codehaus.plexus.util</pattern>
			                  <shadedPattern>org.shaded.plexus.util</shadedPattern>
			                  <excludes>
			                    <exclude>org.codehaus.plexus.util.xml.Xpp3Dom</exclude>
			                    <exclude>org.codehaus.plexus.util.xml.pull.*</exclude>
			                  </excludes>
			                </relocation>
		              </relocations>
		            </configuration>
                 </execution>
             </executions>
</plugin>

4.maven-jar-plugin

<plugin>
	<groupId>org.apache.maven.plugins</groupId>
	<artifactId>maven-jar-plugin</artifactId>
	<version>2.4</version>
	<configuration>
		<archive>
			<!-- 配置生成的jar中,包含pom.xml和pom.properties这两个文件 -->
			<addMavenDescriptor>true</addMavenDescriptor>
			<!-- 生成MANIFEST.MF的设置 -->
			<manifest>
				<!--配置引用的包maven库多个包带时间戳的和不带时间戳的无法对应的错误 -->
				<useUniqueVersions>false</useUniqueVersions>
				<!-- 配置依赖包添加路径, 这些路径会写在MANIFEST文件的Class-Path-->
				<addClasspath>true</addClasspath>
				<!-- 配置jar所依赖的jar包添加classPath的时候的前缀,如果这个jar本身
				和依赖包在同一级目录,则不需要添加 -->
				<classpathPrefix>lib/</classpathPrefix>
				<!-- 配置jar启动入口类 -->
				<mainClass>com.ht.pojo.Test</mainClass>
			</manifest>
			<manifestEntries>
				<!-- 配置Class-Path下添加配置文件的路径 -->
				<Class-Path>../config/</Class-Path>
				<!-- 配项目依赖本地的资源,打包的时候并不想把这些资源文件打进包里面,需要指定资源文件的路径
			</manifestEntries>
		</archive>
		<!-- 配置jar包的位置 -->
		<outputDirectory>${project.build.directory}/lib</outputDirectory>
		<includes>
			<!-- 配置打包class文件和config目录下面的 properties文件 -->
			<!-- 配置可能需要一些其他文件,这边可以配置,包括剔除的文件等等 -->
			<include>**/*.class</include>
			<include>**/*.properties</include>
		</includes>
	</configuration>
</plugin>

5.maven-resources-plugin

 <build>
			  <resources>
			       <resource>
				        <!--配置从此目录下读取全部以.properties和.xml开头的文件-->
				        <directory>src/main/resources/</directory>
				        <includes>
				          <include>**/*.properties</include>
				          <include>**/*.xml</include>
				        </includes>
					</resource>
			        <resource>
		                <directory>src/main/resources</directory>
		                <!--配置过滤上面指定属性文件中的占位符,占位符是${变量名称}这样的形式,maven会自动读取includes配置文件,然后解析其中的占位符,使用上面pom文件中定义的属性进行替换-->
		                <filtering>true</filtering>
		                <includes>
		                    <include>*.yml</include>
		                </includes>
		                <!--配置排除某些-->
		                <excludes>
		                    <exclude>file</exclude>
		                </excludes>
		           </resource>
		       </resources>
  <plugins>
 	<plugin>
 			  <groupId>org.apache.maven.plugins</groupId>
              <artifactId>maven-resources-plugin</artifactId>
              <version>3.2.0</version>
              <executions>
                    <execution>
                        <id>copy-resources</id>
                        <!-- here the phase you need -->
                       <!-- 配置作用周期-->
                        <phase>validate</phase>
                        <goals>
                            <goal>copy-resources</goal>
                        </goals>
                        <configuration>
                              <outputDirectory>${basedir}/target/extraresources</outputDirectory>
                              <resources>          
                                  <resource>
                                      <directory>src/non-packaged-resources</directory>
                                      <filtering>true</filtering>
                                  </resource>
                              </resources>              
                        </configuration>            
                  </execution>
              </executions>
	</plugin>
  </plugins>
</build>

6.maven-compiler-plugin

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <version>3.1</version>
    <configuration>
    	<!-- 配置指定的 JDK 版本将 java 文件编译为 class 文件(针对编译运行环境) -->
        <source>1.6</source> 
        <!-- 配置指定的 JDK 版本对源代码进行编译(针对编译运行环境) -->
        <target>1.6</target> 
        <!-- 配置程序能在其他版本的jdk中运行(对于低版本目标jdk,源代码中需要没有使用低版本jdk中不支持的语法),会存在target不同于source的情况 -->
	   <compilerArgs> 
	  			<!--配置javac平时用空格隔开的的每一个参数-->
	            <arg>-verbose</arg>
	            <arg>-Xlint:unchecked</arg>
	            <arg>-Xlint:deprecation</arg>
	            <arg>-bootclasspath</arg>
	            <arg>${env.JAVA_HOME}/jre/lib/rt.jar${path.separator}${env.JAVA_HOME}/lib/jce.jar</arg>
	            <arg>-extdirs</arg> 
	            <arg>${project.basedir}/src/main/webapp/WEB-INF/lib</arg>
	   </compilerArgs> 
    </configuration>
</plugin>

7.maven-dependency-plugin文章来源地址https://www.toymoban.com/news/detail-640928.html

 <plugin>  
            <groupId>org.apache.maven.plugins</groupId>  
            <artifactId>maven-dependency-plugin</artifactId>  
            <version>2.8</version>  
            <executions>  
                <execution>  
                    <phase>package</phase>  
                    <goals>  
                    	<!--配置copy操作可以用来将某个maven artifact(s)拷贝到某个目录下-->
                        <goal>copy</goal>  
                    </goals>  
                </execution>  
                <execution>  
			        <phase>package</phase>  
			        <goals>  
			        	<!--配置unpack操作可以用来将某个maven artifact(s)拷贝到某个目录下-->
			            <goal>unpack</goal>  
			        </goals>
			        <configuration>
		                <type>jar</type>
		                <includeTypes>jar</includeTypes>
		                <outputDirectory>
		                    ${project.build.directory}/lib
		                </outputDirectory>
		                <!-- 配置是否排除间接依赖 默认false 不排除 -->
		                <excludeTransitive>false</excludeTransitive>
		                <!-- 配置是否消除依赖jar包后缀的版本信息 默认是false 不取消版本信息-->
		                <stripVersion>false</stripVersion>
            		</configuration>
       		   </execution>
            </executions>
            <!--配置排除所有camel的依赖-->
            <configuration>  
    			<excludeGroupIds>org.apache.camel</excludeGroupIds>  
			</configuration>
			<!--配置排除除camel-spring外的所有其他依赖-->
			<configuration>  
			    <includeArtifactIds>camel-spring</includeArtifactIds>  
			</configuration>
</plugin>

到了这里,关于【Maven】打包插件使用详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • maven打包spring boot jar没有 BOOT-INF目录解决方案

    ##查看项目里面是否有引入spring-boot-maven-plugin plugin           groupIdorg.springframework.boot/groupId           artifactIdspring-boot-maven-plugin/artifactId         /plugin ##如果有引入,还不行 ##查看pom.xml是否有pluginManagement标签,去掉pluginManagement就行了 ##去掉pluginManagement标签

    2024年01月18日
    浏览(34)
  • Maven打包失败--Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:no found...

    1、问题还原,无论怎样操作,打包都是失败 Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:2.3.4.RELEASE:repackage (repackage) on project guigu-common: Execution repackage of goal org.springframework.boot:spring-boot-maven-plugin:2.3.4.RELEASE:repackage failed: Unable to find main class - [Help 1] [ERROR]  2、这个问

    2024年02月03日
    浏览(38)
  • 找不到插件 ‘org.springframework.boot:spring-boot-maven-plugin:‘问题

    出现pom文件找不到插件 ‘org.springframework.boot:spring-boot-maven-plugin:‘问题, 可能是因为版本没有绑定好,去一级父类依赖找对应的插件版本,在pom文件中加上。 把父类的version加到pom中   出现这个说明已经绑定好了,删除版本也可以    

    2024年02月07日
    浏览(34)
  • 构建SpringBoot工程时找不到插件“spring-boot-maven-plugin”

    目录 一、找不到插件“spring-boot-maven-plugin” 二、再次启动时,又发现报错         Unable to find a single main class from the following candidates [com.itheima.Application, com.example.springboot01.Springboot01Application]上面报错的意思是,有多个App类,它不知用哪个  三、把该插件打包后,在jar包的

    2024年02月07日
    浏览(44)
  • bug1-找不到插件 ‘org.springframework.boot:spring-boot-maven-plugin:‘

    项目无缘无故出现此问题,在该位置加上版本号后解决。 步骤1:点击groudid进入spring-boot-maven-plugin-2.4.1.pom 步骤2:在spring-boot-maven-plugin-2.4.1.pom文件中找到报错的spring-boot-maven-plugin 步骤3:可以找到对应的版本号,将此版本号,添加到报错的位置。 步骤4:刷新maven,解决此问题。

    2024年02月16日
    浏览(34)
  • 【Maven】SpringBoot项目使用maven-assembly-plugin插件多环境打包

    1.创建SpringBoot项目并在pom.xml文件中添加maven-assembly-plugin配置 2.创建 在src/main/assembly目录下创建assembly.xml文件 3.在src/main/bin创建在linux环境启动jar包的脚本 4.配置application.yml文件 5.启动项目 6.打包 7.打包后的目录结构 8.上传到linux服务器并启动jar包 9.调用接口测试 10.源码地址

    2024年02月12日
    浏览(34)
  • Idea使用Docker插件实现maven打包自动构建镜像

    Docker 开启TCP 服务 改写以下内容 重启服务 此时docker已经开放了2375端口,使用外部主机访问 http://docker:2375/info IDEA 集成Docker 安装Docker 插件 配置docker服务地址 点击view-services,打开docker的操作面板 双击docker01可以看到此docker服务下镜像和容器 右击docker镜像,可以创建新的容器,

    2024年02月10日
    浏览(34)
  • 【微服务部署】三、Jenkins+Maven插件Jib一键打包部署SpringBoot应用Docker镜像步骤详解

      前面我们介绍了K8S+Docker+Maven插件打包部署SpringCloud微服务项目,在实际应用过程中,很多项目没有用到K8S和微服务,但是用到了Docker和SpringBoot,所以,我们这边介绍,如果使用Jenkins+jib-maven-plugin插件打包部署SpringBoot项目的Docker镜像。   网上有多种Docker打包插件使用说

    2024年02月09日
    浏览(27)
  • SpringBoot 插件 spring-boot-maven-plugin 原理,以及SpringBoo工程部署的 jar 包瘦身实战

    我们直接使用 maven package (maven自带的package打包功能),打包Jar包的时候,不会将该项目所依赖的Jar包一起打进去,在使用 java -jar 命令启动项目时会报错,项目无法正常启动。这个时候,我们就可以考虑引用 spring-boot-maven-plugin 插件来为项目打Jar包。 maven项目的pom.xml中,添

    2024年02月06日
    浏览(35)
  • 【JAVA EE】Spring Boot中maven环境的搭建和设置

    Sping Boot是Spring推出的框架,是Spring家族的一个子项目,其设计初衷是为了简化Spring配置,从而让用户可以轻松构建独立运行的程序,并极大提高工作效率。 本系列将学习Spring Boot的相关原理和简单开发。 在Spring Boot框架出现以前,java EE开发常用的框架是Spring,该框架开始于

    2024年02月06日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包