maven-assembly-plugin插件

当你使用 Maven 对项目打包时,你需要了解以下 3 个打包 plugin,它们分别是

pluginfunction
maven-jar-pluginmaven 默认打包插件,用来创建 project jar
maven-shade-plugin用来打可执行包,executable(fat) jar
maven-assembly-plugin支持定制化打包方式,例如 apache 项目的打包方式

下面我们就简单介绍一下 maven-assembly-plugin。

使用方法

  • 使用 descriptorRefs(官方提供的定制化打包方式),官方提供的 descriptorRef 有 bin, jar-with-dependencies, src, project。【不建议使用】
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<project>
[...]
<build>
  [...]
  <plugins>
    <plugin>
      <!-- NOTE: We don't need a groupId specification because the group is
            org.apache.maven.plugins ...which is assumed by default.
        -->
      <artifactId>maven-assembly-plugin</artifactId>
      <version>3.0.0</version>
      <configuration>
        <descriptorRefs>
          <descriptorRef>jar-with-dependencies</descriptorRef>
        </descriptorRefs>
      </configuration>
      [...]
</project>
  • 使用 descriptors,指定打包文件 src/assembly/src.xml,在该配置文件内指定打包操作。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<project>
[...]
 <build>
  [...]
   <plugins>
     <plugin>
       <artifactId>maven-assembly-plugin</artifactId>
       <version>3.0.0</version>
       <configuration>
         <descriptors>
           <descriptor>src/assembly/src.xml</descriptor>
         </descriptors>
       </configuration>
      [...]
</project>

描述符文件元素

id

<id>release</id>

id 标识符,添加到生成文件名称的后缀符。如果指定 id 的话,目标文件则是{artifactId}-.tar.gz

formats

maven-assembly-plugin 支持的打包格式有zip、tar、tar.gz (or tgz)、tar.bz2 (or tbz2)、jar、dir、war,可以同时指定多个打包格式

1
2
3
4
  <formats>
   <format>tar.gz</format>
   <format>dir</format>
 </formats>

dependencySets

用来定制工程依赖 jar 包的打包方式,核心元素如下表所示。

元素类型作用
outputDirectoryString指定包依赖目录,该目录是相对于根目录
includes/include*List包含依赖
excludes/exclude*List排除依赖
1
2
3
4
5
<dependencySets>
   <dependencySet>
     <outputDirectory>/lib</outputDirectory>
   </dependencySet>
 </dependencySets>

fileSets

管理一组文件的存放位置,核心元素如下表所示。

元素类型作用
outputDirectoryString指定文件集合的输出目录,该目录是相对于根目录
includes/include*List包含文件
excludes/exclude*List排除文件
fileModeString指定文件属性,使用八进制表达,分别为(User)(Group)(Other)所属属性,默认为 0644
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
  <fileSets>
   <fileSet>
     <includes>
       <include>bin/**</include>
     </includes>
     <fileMode>0755</fileMode>
   </fileSet>

   <fileSet>
     <includes>
       <include>/conf/**</include>
       <include>logs</include>
     </includes>
   </fileSet>

 </fileSets>

files

可以指定目的文件名到指定目录,其他和 fileSets 相同,核心元素如下表所示。

元素类型作用
sourceString源文件,相对路径或绝对路径
outputDirectoryString输出目录
destNameString目标文件名
fileModeString设置文件 UNIX 属性
1
2
3
4
5
6
<files>
   <file>
     <source>README.txt</source>
     <outputDirectory>/</outputDirectory>
   </file>
 </files>

样例

工程目录结构

scribe-log4j2-test

pom.xml

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
<build>
 <finalName>scribe-log4j2-test</finalName>
 <plugins>
   <plugin>
     <groupId>org.apache.maven.plugins</groupId>
     <artifactId>maven-compiler-plugin</artifactId>
   </plugin>

   <plugin>
     <groupId>org.apache.maven.plugins</groupId>
     <artifactId>maven-assembly-plugin</artifactId>
     <configuration>
       <descriptors>
         <descriptor>src/main/assembly/release.xml</descriptor>
       </descriptors>
     </configuration>

     <executions>
       <execution>
         <id>make-assembly</id> <!-- this is used for inheritance merges -->
         <phase>package</phase> <!-- bind to the packaging phase -->
         <goals>
           <goal>single</goal>
         </goals>
       </execution>
     </executions>
   </plugin>
 </plugins>
</build>

release.xml

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
40
<assembly xmlns="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.3"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.3 http://maven.apache.org/xsd/assembly-1.1.3.xsd">

 <formats>
   <format>tar.gz</format>
   <format>dir</format>
 </formats>

 <dependencySets>
   <dependencySet>
     <outputDirectory>/lib</outputDirectory>
   </dependencySet>
 </dependencySets>

 <fileSets>
   <fileSet>
     <includes>
       <include>bin/**</include>
     </includes>
     <fileMode>0755</fileMode>
   </fileSet>

   <fileSet>
     <includes>
       <include>/conf/**</include>
       <include>logs</include>
     </includes>
   </fileSet>

 </fileSets>

 <files>
   <file>
     <source>README.txt</source>
     <outputDirectory>/</outputDirectory>
   </file>
 </files>

</assembly>

最终创建生成可执行二进制工程

参考

maven 入门指南 maven 生命周期 Maven 默认插件以及功能 maven 依赖管理 maven-shade-plugin 入门指南 maven-assembly-plugin