一.官方文档
http://maven.apache.org/plugins/maven-assembly-plugin/assembly.html
二.说明
- 作用
- 英文原文:The Assembly Plugin for Maven is primarily intended to allow users to aggregate the project output along with its dependencies, modules, site documentation, and other files into a single distributable archive.
- 中文翻译:Assembly 插件的主要作用是,允许用户将项目输出与它的依赖项、模块、站点文档、和其他文件一起组装成一个可分发的归档文件。
- 在Maven中,主要有3个插件可以用来打包:
- maven-jar-plugin,默认的打包插件,用来打普通的project JAR包;
- maven-shade-plugin,用来打可执行JAR包,也就是所谓的fat JAR包;
- maven-assembly-plugin,支持自定义的打包结构,也可以定制依赖项等。
我们日常使用的以maven-assembly-plugin为最多,因为大数据项目中往往有很多shell脚本、SQL脚本、.properties及.xml配置项等,采用assembly插件可以让输出的结构清晰而标准化。
要使用该插件,就在POM中加入以下内容。
三.pom文件配置示例
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<build>
<resources>
<!--指定src/main/resources资源要过滤-->
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
<plugins>
<!-- 可执行jar插件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<!-- 配置描述符文件 --><!-- 也可以使用Maven预配置的描述符 -->
<descriptor>src/main/assembly/assembly.xml</descriptor>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
<archive>
<manifest>
<!--指定主程序入口-->
<mainClass>com.oracle.JDBCMain</mainClass>
</manifest>
</archive>
</configuration>
<executions>
<!--执行器 mvn assembly:assembly-->
<execution>
<id>make-assembly</id>
<!--绑定到package生命周期阶段上-->
<phase>package</phase>
<goals>
<!--该打包任务只运行一次-->
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>6</source>
<target>6</target>
</configuration>
</plugin>
</plugins>
</build>
四.assembly.xml(配置描述符文件示例)
- assembly插件的打包方式是通过descriptor(描述符)来定义的。
- Maven预先定义好的描述符有bin,src,project,jar-with-dependencies等。比较常用的是jar-with-dependencies,它是将所有外部依赖JAR都加入生成的JAR包中,比较傻瓜化。
- 但要真正达到自定义打包的效果,就需要自己写描述符文件,格式为XML。下面是我们的项目中常用的一种配置。
<?xml version="1.0" encoding="utf-8"?>
<assembly
xmlns="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.2"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.2 http://maven.apache.org/xsd/assembly-1.1.2.xsd">
<!-- id 标识符,添加到生成文件名称的后缀符。如果指定 id 的话(这里指定的是项目的版本),目标文件则是 ${artifactId}-${id}.jar。【如terminal-dispatch-5.0.0.0.jar】 -->
<id>assembly</id>
<!-- 指定打包格式。maven-assembly-plugin插件支持的打包格式有zip、tar、tar.gz (or tgz)、tar.bz2 (or tbz2)、jar、dir、war,可以同时指定多个打包格式 -->
<formats>
<format>tar.gz</format>
</formats>
<!-- 指定打的包是否包含打包层目录(比如finalName是terminal-dispatch,当值为true,所有文件被放在包内的terminal-dispatch目录下,否则直接放在包的根目录下)-->
<includeBaseDirectory>true</includeBaseDirectory>
<!-- 指定将工程依赖的包打到包里的指定目录下 -->
<dependencySets>
<dependencySet>
<unpack>false</unpack> <!--布尔值,false表示将依赖以原来的JAR形式打包,true则表示将依赖解成*.class文件的目录结构打包。-->
<scope>runtime</scope> <!-- 用于管理依赖的部署,runtime表示只在运行时使用 -->
<outputDirectory>lib</outputDirectory>
<useProjectArtifact>true</useProjectArtifact> <!-- 指定打包时是否包含工程自身生成的jar包 -->
<outputDirectory>lib</outputDirectory> <!-- 指定将这些依赖包打到包里lib目录下 -->
</dependencySet>
</dependencySets>
<fileSets>
<fileSet>
<directory>src/main/script/linux/bin</directory> <!-- 指定归档文件(要打的jar包)要包含的目录(下的文件及文件夹) -->
<outputDirectory>bin</outputDirectory> <!-- 指定要将当前目录(<directory>标签中的目录放在归档文件(要打的jar包)bin目录下) -->
<includes>
<include>terminal-dispatch</include> <!-- 精确控制要包含的文件,<exclude>用于精确控制要排除的文件 -->
<include>server</include>
</includes>
<fileMode>0755</fileMode> <!-- 设置文件 UNIX 属性,是一种读写权限 -->
</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>
<files>
<file>
<source>target/${project.artifactId}-${project.version}.jar</source>
<outputDirectory>.</outputDirectory>
</file>
</files>
</assembly>
4.1 < id>与 < format> 配置
- <id>: 添加到打包文件名的标识符,用来做后缀。
- <format> : assembly插件支持的打包文件格式,有zip、tar、tar.gz、tar.bz2、jar、war。可以同时定义多个format。
<!-- id 标识符,添加到生成文件名称的后缀符。如果指定 id 的话(这里指定的是项目的版本),目标文件则是 ${artifactId}-${id}.jar。【如terminal-dispatch-5.0.0.0.jar】 -->
<id>assembly</id>
<!-- 指定打包格式。maven-assembly-plugin插件支持的打包格式有zip、tar、tar.gz (or tgz)、tar.bz2 (or tbz2)、jar、dir、war,可以同时指定多个打包格式 -->
<formats>
<format>tar.gz</format>
</formats>
如果按上面的配置,生成的文件就是=> artifactId−artifactId−{version}-assembly.tar.gz
4.2 < includeBaseDirectory> 配置
- 作用: 指定打的包是否包含打包层目录,比如finalName是terminal-dispatch,当值为true,所有文件被放在包内的terminal-dispatch目录下,否则直接放在包的根目录下
<!-- 指定打的包是否包含打包层目录(比如finalName是terminal-dispatch,当值为true,所有文件被放在包内的terminal-dispatch目录下,否则直接放在包的根目录下)-->
<includeBaseDirectory>true</includeBaseDirectory>
4.3 < dependencySets> 和 < dependencySet> 配置
- 作用 : 用来设置工程依赖文件在打包时的属性。也与fileSets大致相同,不过还有两个特殊的配置:
- <unpack>:布尔值,false表示将依赖以原来的JAR形式打包,true则表示将依赖解成*.class文件的目录结构打包。
- <scope>:表示符合依赖的作用域,一般是写runtime。
- <outputDirectory>:生成目录的路径。
- <useProjectArtifact> : 指定打包时是否包含工程自身生成的jar包。
关于scope作用域
序号 | 取值 | 意义 |
1 | compile | 缺省值,适用于所有阶段,会随着项目一起发布 |
2 | provided | 类似compile,期望JDK、容器或使用者会提供这个依赖。如servlet.jar |
3 | runtime | 只在运行时使用,如JDBC驱动,适用运行和测试阶段 |
4 | test | 只在测试时使用,用于编译和运行测试代码。不会随项目发布 |
5 | system | 类似provided,需要显式提供包含依赖的jar,Maven不会在Repository中查找它 |
<!-- 指定将工程依赖的包打到包里的指定目录下 -->
<dependencySets>
<dependencySet>
<unpack>false</unpack> <!--布尔值,false表示将依赖以原来的JAR形式打包,true则表示将依赖解成*.class文件的目录结构打包。-->
<scope>runtime</scope> <!-- 用于管理依赖的部署,runtime表示只在运行时使用 -->
<outputDirectory>lib</outputDirectory>
<useProjectArtifact>true</useProjectArtifact> <!-- 指定打包时是否包含工程自身生成的jar包 -->
<outputDirectory>lib</outputDirectory> <!-- 指定将这些依赖包打到包里lib目录下 -->
</dependencySet>
</dependencySets>
4.4 < fileStes> 和 < fileSet> 配置
- 作用 : 用来设置一组文件在打包时的属性
- <directory>:源目录的路径。
- <includes>/<excludes>:设定包含或排除哪些文件,支持通配符。
- <outputDirectory>:生成目录的路径。
- <fileMode>:指定该目录下的文件属性,采用Unix八进制描述法,默认值是0644。关于LINUX中的权限 - 点击跳转
4.5 < files> 和 < file> 配置
- 作用 : 用来设置单个文件在打包时的属性
- 与<fileSets>类似,不过是指定单个文件,并且还可以通过<destName>属性来设置与源文件不同的名称。
- <source> : 源文件的路径
- <outputDirectory> : 生成目录的路径。 .表示当前目录
<files>
<file>
<source>target/${project.artifactId}-${project.version}.jar</source>
<outputDirectory>.</outputDirectory>
</file>
</files>
按照以上配置打包好后,将.tar.gz文件上传到服务器,解压之后就会得到bin、conf、lib等规范化的目录结构,十分方便。
五.基本用法
点击Terminal进入仿真界面,输入
mvn clean package
演示打包文件非上述(三、四)示例中配置的内容
在工作目录下的target目录下(我这里D:\develop\IDEA\workspace\20200528_DatabasesConnectivityTest\target)
生成了最终执行文件
20200528_DatabasesConnectivityTest-1.0-SNAPSHOT-jar-with-dependencies.jar
参考文章
1.Maven assembly实现自定义打包 ---- chenlly992.使用maven-assembly-plugin打包,assembly的语法介绍(同时打多个包、排除依赖包、文件更改别名、自定义路径) ---- toocarrie3.Maven3种打包方式之一maven-assembly-plugin的使用 ---- Hellooorld4.maven-assembly-plugin插件的使用方法 ---- weixin_337438805.IDEA中MAVEN项目打JAR包的简单方法 ---- spring-boot-maven-plugin 阿丙6.Linux 中的权限 – 0755 和 0644 ---- dijkstar
20/06/05
M