maven-assembly-plugin插件详解

本文详细介绍了Maven Assembly插件的使用方法,包括如何通过Assembly描述符文件指定打包格式、包含的文件和过滤的文件,以及如何在Maven项目中配置插件。文章还提供了示例代码,展示了如何指定打包格式、文件集、依赖项和文件权限。

maven-assembly-plugin插件详解
maven-assembly-plugin插件,以下简称assembly插件。

  1. assembly插件是什么?
    assembly插件是maven中针对打包任务而提供的标准插件。

  2. assembly插件的作用
    Assembly 插件的主要作用是,允许用户将项目输出与它的依赖项、模块、站点文档、和其他文件一起组装成一个可分发的归档文件。

  3. assembly插件在maven项目中的使用
      (1)需要指定一个Assembly描述符文件。该文件指定了打包格式,包含的文件/过滤的文件等信息,可以同时指定多个描述符文件,打包成不同的格式。
      (2)在Maven工程的pom.xml文件里配置maven-assembly-plugin插件,引入Assembly描述符文件。

  4. maven项目中Assembly描述符文件详解
    示例:

<?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。【如yigo-core.jar】 -->
    <id>${project.version}</id>
    
    <!-- 指定打包格式。maven-assembly-plugin插件支持的打包格式有zip、tar、tar.gz (or tgz)、tar.bz2 (or tbz2)、jar、dir、war,可以同时指定多个打包格式 -->
    <formats>
        <format>jar</format>
    </formats>
    
    <!-- 指定打的包是否包含打包层目录(比如finalName是yigo-core,当值为true,所有文件被放在包内的yigo-core目录下,否则直接放在包的根目录下)-->
    <includeBaseDirectory>true</includeBaseDirectory>
    
    <!-- 指定将工程依赖的包打到包里的指定目录下 -->
    <dependencySets>
        <dependencySet>
            <useProjectArtifact>true</useProjectArtifact> <!-- 指定打包时是否包含工程自身生成的jar包 -->
            <outputDirectory>lib</outputDirectory> <!-- 指定将这些依赖包打到包里lib目录下 -->
            <scope>runtime</scope> <!-- 用于管理依赖的部署,runtime表示只在运行时使用 -->
        </dependencySet>
    </dependencySets>
    
    <!-- 指定要包含的文件集,可以定义多个fileSet -->
    <fileSets>
        <fileSet>
            <directory>src/main/script/linux/bin</directory> <!-- 指定归档文件(要打的jar包)要包含的目录(下的文件及文件夹) -->
            <outputDirectory>bin</outputDirectory> <!-- 指定要将当前目录(<directory>标签中的目录放在归档文件(要打的jar包)bin目录下) -->
            <includes>
                <include>yigo-core</include> <!-- 精确控制要包含的文件,<exclude>用于精确控制要排除的文件  -->
                <include>server</include>
            </includes>
            <fileMode>0755</fileMode> <!-- 设置文件 UNIX 属性,是一种读写权限 -->
        </fileSet>        
        <fileSet>
            <directory>src/main/resources</directory>
            <outputDirectory>conf</outputDirectory>
            <includes>
                <include>config.properties</include>
                <include>logback.xml</include>
            </includes>
            <fileMode>0644</fileMode>
        </fileSet>
        <fileSet>
            <directory>src/main/script/conf</directory>
            <outputDirectory>conf</outputDirectory>
            <includes>
                <include>wrapper.conf</include>
            </includes>
            <fileMode>0644</fileMode>
        </fileSet>
        <fileSet>
            <directory>src/main/script/linux/lib</directory>
            <outputDirectory>lib</outputDirectory>
            <includes>
                <include>libwrapper.so</include>
                <include>wrapper.jar</include>
            </includes>
            <fileMode>0755</fileMode>
        </fileSet>
    </fileSets>
    
</assembly>

属性解释:

(1) includeBaseDirectory标签的作用

指定打的包是否包含打包层目录,比如finalName是yigo-core,当值为true,所有文件被放在包内的yigo-core目录下,否则直接放在包的根目录下,如下图所示:
   在这里插入图片描述

(2)fileMode标签的作用

设置文件的unix属性,好像是一种读写权限的设定,linux的内容,我没有深究,不是特别懂,暂时不多说。

序号取值意义
1compile缺省值,适用于所有阶段,会随着项目一起发布
2provided类似compile,期望JDK、容器或使用者会提供这个依赖。如servlet.jar
3runtime只在运行时使用,如JDBC驱动,适用运行和测试阶段
4test只在测试时使用,用于编译和运行测试代码。不会随项目发布
5system类似provided,需要显式提供包含依赖的jar,Maven不会在Repository中查找它
  1. 在pom.xml 文件引入assembly描述符文件
<build>
    <plugins>
       <plugin>
         <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-assembly-plugin</artifactId>
      <version>2.4</version>
        <executions>
          <execution> <!--执行器 mvn assembly:assembly-->
            <id>make-zip</id> <!--名字任意 -->
            <phase>package</phase> <!-- 绑定到package生命周期阶段上 -->
            <goals>
              <goal>single</goal> <!-- 该打包任务只运行一次 -->
            </goals>
            <configuration>
              <descriptors
                <descriptor>src/main/script/release-yigo.xml</descriptor> 
              </descriptors>
          </configuration>
        </execution>
      </executions>
    </plugin>
    <plugins>
</build>
<think> 我们正在讨论的是maven-assembly-plugin的配置方法。根据引用内容,我们可以总结出以下步骤和关键点: 1. **插件作用**:maven-assembly-plugin用于创建自定义的分发包,可以包含项目的构建输出、依赖项、模块、配置文件等,支持多种格式如ZIP、TAR等(引用[2][3][4])。 2. **基本配置步骤**: - 在pom.xml中配置插件引用。 - 编写一个assembly描述符文件(XML格式)来定义打包的结构和内容。 -插件绑定到Maven的生命周期阶段(通常是package阶段)。 3. **具体配置示例**(引用[5]): ```xml <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-assembly-plugin</artifactId> <version>3.6.0</version> <!-- 建议指定版本 --> <configuration> <descriptors> <descriptor>src/main/assembly/release.xml</descriptor> <!-- 指定描述符文件路径 --> </descriptors> </configuration> <executions> <execution> <id>make-assembly</id> <phase>package</phase> <!-- 绑定到package阶段 --> <goals> <goal>single</goal> <!-- 执行single目标 --> </goals> </execution> </executions> </plugin> </plugins> </build> ``` 4. **Assembly描述符文件详解**(引用[1]): - 描述符文件定义了打包的内容、结构和格式。 - 常用标签: - `id`: 打包的标识符,会附加到生成的文件名中。 - `formats`: 打包格式,如`zip`、`tar`等。 - `includeBaseDirectory`: 是否包含一个以`artifactId`和`version`命名的基目录(默认为true)。 - `fileMode`: 设置文件的UNIX权限(八进制数,如0755)。 - `directoryMode`: 设置目录的UNIX权限。 5. **关于引用[1]中提到的两个问题**: - `includeBaseDirectory`为true时,会在压缩包内创建一个以项目`artifactId`和`version`命名的基目录,所有文件都放在这个目录下。如果为false,则文件直接放在压缩包的根目录下。 - `fileMode`标签用于设置文件的权限,0755表示所有者有读、写、执行权限(7),同组用户和其他用户有读和执行权限(5)。注意:在Windows系统上可能无效。 6. **一个简单的描述符文件示例**(参考引用[2]): ```xml <assembly xmlns="http://maven.apache.org/ASSEMBLY/2.1.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.1.0 http://maven.apache.org/xsd/assembly-2.1.0.xsd"> <id>release</id> <formats> <format>zip</format> </formats> <includeBaseDirectory
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值