assembly例子https://github.com/javahongxi/whatsmars/tree/master/whatsmars-spring
一、多模块打包
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <artifactId>whatsmars-parent</artifactId> <groupId>com.itlong</groupId> <version>1.0-SNAPSHOT</version> </parent> <modelVersion>4.0.0</modelVersion> <artifactId>earth</artifactId> <packaging>jar</packaging> <name>${project.artifactId}</name> <description>The all in one project of whatsmars-earth</description> <properties> <skip_maven_deploy>false</skip_maven_deploy> </properties> <dependencies> <dependency> <groupId>com.itlong</groupId> <artifactId>whatsmars-common</artifactId> <version>${project.parent.version}</version> </dependency> <dependency> <groupId>com.itlong</groupId> <artifactId>whatsmars-earth-domain</artifactId> <version>${project.parent.version}</version> </dependency> <dependency> <groupId>com.itlong</groupId> <artifactId>whatsmars-earth-dao</artifactId> <version>${project.parent.version}</version> </dependency> <dependency> <groupId>com.itlong</groupId> <artifactId>whatsmars-earth-service</artifactId> <version>${project.parent.version}</version> </dependency> </dependencies> <build> <plugins> <plugin> <artifactId>maven-source-plugin</artifactId> <executions> <execution> <id>attach-sources</id> <phase>none</phase> </execution> </executions> </plugin> <plugin> <artifactId>maven-javadoc-plugin</artifactId> <executions> <execution> <id>attach-javadoc</id> <phase>deploy</phase> <goals> <goal>jar</goal> </goals> </execution> </executions> <configuration> <show>public</show> <charset>UTF-8</charset> <encoding>UTF-8</encoding> <docencoding>UTF-8</docencoding> <excludePackageNames>com.itlong.com.*</excludePackageNames> <links> <link>http://docs.oracle.com/javase/6/docs/api</link> </links> </configuration> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>1.4</version> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> <configuration> <createSourcesJar>false</createSourcesJar> <promoteTransitiveDependencies>true</promoteTransitiveDependencies> <artifactSet> <includes> <!-- 这里只是随便拿了几个模块来作为例子,实际上如下模块是不应该打包在一起的 --> <include>com.itlong:whatsmars-common</include> <include>com.itlong:whatsmars-earth-domain</include> <include>com.itlong:whatsmars-earth-dao</include> <include>com.itlong:whatsmars-earth-service</include> </includes> </artifactSet> <transformers> </transformers> </configuration> </execution> </executions> </plugin> </plugins> </build> </project>
二、assembly
你是否想要创建一个包含脚本、配置文件以及所有运行时所依赖的元素(jar)Assembly插件能帮你构建一个完整的发布包。
Assembly插件会生成 “assemblies”, 此特性等同于的Maven 1 distribution plug-in.。该插件不仅支持创建二进制归档文件,也支持创建源码归档文件。这些assemblies定义在一个assembly描述符文件里。你可以选择自定义assembly描述符或者直接使用插件自带的三个预定义描述符中的任何一个.
目前Assembly插件支持如下格式的归档文件:
- zip
- tar.gz
- tar.bz2
- jar
- dir
- war
- and any other format that the ArchiveManager has been configured for
Maven 2上使用assembly的简单步骤:
- 从预定义描述符里选择一个或者自己编写一个assembly描述符号。
- 工程的pom.xml里配置Assembly插件。
- 在工程根目录下运行”mvn assembly:assembly”命令 。
如何自定义assembly描述符,详见Assembly Descriptor Format.
什么是Assembly?
“assembly”是把一组文件、目录、依赖元素组装成一个归档文件. 比如, 假设一个 Maven project定义了一个JAR artifact,它包含控制台应用程序和Swing应用程序 。这样一个工程可以定义两套包含描述符,一套给给控制台应用,另一套给Swing应用程序,它们包含各自的脚本、目录和依赖。
Assembly Plugin的描述符可以定义任何一个文件或者目录归档方式。举个例子,如果的你的Maven 2工程包含”src/main/bin”这个目录,你可以指示Assembly插件复制“src/main/bin”目录下所有的文件到bin目录里(归档文件里的目录),并且可以修改它们的权限属性(UNIX mode)。见 assembly descriptor.
The Maven Assembly Plugin
Maven 2.0的Assembly插件目的是提供一个把工程依赖元素、模块、网站文档等其他文件存放到单个归档文件里。
使用任何一个预定义的描述符你可以轻松的构建一个发布包。这些描述符能处理一些常用的操作,如:把依赖的元素的归档到一个jar文件. 当然, 你可以自定义描述符来更灵活的控制依赖,模块,文件的归档方式。
maven-assembly-plugin : 是maven中针对打包任务而提供的标准插件
(1)、在pom.xml 文件里面的配置说明
- <plugin>
- <artifactId>maven-assembly-plugin</artifactId>
- <executions> <!--执行器 mvn assembly:assembly-->
- <execution>
- <id>make-zip</id><!--名字任意 -->
- <phase>package</phase><!-- 绑定到package生命周期阶段上 -->
- <goals>
- <goal>single</goal><!-- 只运行一次 -->
- </goals>
- <configuration>
- <descriptors> <!--描述文件路径-->
- <descriptor>src/main/resources/zip.xml</descriptor>
- </descriptors>
- </configuration>
- </execution>
- </executions>
- </plugin>
(2)、zip.xml 文件配置如下
- <assembly
- xmlns="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.0"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.0 http://maven.apache.org/xsd/assembly-1.1.0.xsd">
- <id>release</id>
- <formats>
- <format>zip</format>
- </formats>
- <fileSets>
- <fileSet>
- <directory>${project.basedir}\src\main\config</directory>
- <!-- 过滤 -->
- <excludes>
- <exclude>*.xml</exclude>
- </excludes>
- <outputDirectory>\</outputDirectory>
- </fileSet>
- </fileSets>
- <dependencySets>
- <dependencySet>
- <useProjectArtifact>true</useProjectArtifact>
- <outputDirectory>lib</outputDirectory><!-- 将scope为runtime的依赖包打包到lib目录下。 -->
- <scope>runtime</scope>
- </dependencySet>
- </dependencySets>
- </assembly>
(3)、zip.xml 格式属性说明
打包的文件格式
可以有:tar.zip war zip
<formats>
<format>zip</format>
</formats>
需要打包的路径
<directory>${project.basedir}</directory>
打包后输出的路径
<outputDirectory>/</outputDirectory>
打包需要包含的文件
<excludes>
<exclude>junit:junit</exclude>
<exclude>commons-lang:commons-lang</exclude>
<exclude>commons-logging:commons-logging</exclude>
</excludes>
当前项目构件是否包含在这个依赖集合里。
<useProjectArtifact>true</useProjectArtifact>
依赖包打包到目录下
<dependencySets>
<dependencySet>
<outputDirectory>lib</outputDirectory><!-- 将scope为runtime的依赖包打包到lib目录下。 -->
<useProjectArtifact>true</useProjectArtifact>
<scope>runtime</scope>
</dependencySet>
</dependencySets>
相关推荐
在软件开发过程中,经常需要将多个JAR包合并成一个JAR包,以方便管理和部署。本文将详细介绍如何实现这一过程,并提供具体的操作步骤和技术细节。 ### 一、概述 在Java开发中,项目通常会依赖多个外部库或模块,...
1. 整个项目被打包成一个ZIP文件,包含应用程序、其依赖的JAR包和说明文档。 2. JAR包应可执行,可以从不同类中的Main函数启动。 3. 项目源码和第三方依赖的JAR包要分开打包。 4. 项目中的执行脚本需要一起打包并...
为了简化项目结构、减少资源占用以及方便管理,开发者有时会选择将多个JAR包合并成一个单一的JAR包。这个过程被称为JAR文件的合并。本文将详细讲解如何进行这项操作,并分享一个实用的合并工具。 首先,理解JAR文件...
通过以上步骤,你可以成功地将多个Spring Boot项目打包成一个jar,并理解其中涉及的核心概念和技术。希望提供的源代码能帮助你更好地理解和实践这个过程。在开发过程中,遇到问题时,查阅Spring Boot和构建工具的...
首先,打包成第三方JAR包且包含依赖的方法通常用到的是Maven Assembly插件,它能够帮助我们把所有依赖的JAR包以及主程序一起打包成一个单独的可执行的超级JAR文件。要完成这个过程,需要以下步骤: 1. 在项目的POM...
【fat-Jar打包插件】是一种在Java开发中常用的工具,它的主要作用是将一个项目的所有依赖库(包括第三方jar包)与源代码一起打包成一个独立的jar文件,因此被称为"fat"或"uber"jar。这个插件极大地简化了项目的部署...
Maven Assembly Plugin 是一个强大的工具,主要用于将项目的输出及其依赖项、模块、站点文档和其他相关文件合并到一个可分发的归档文件中。这对于创建最终可部署的包非常有用,特别是在企业环境中,需要将多个组件和...
通过配置这两个插件的pom.xml文件,开发者可以选择性地包含或排除特定的依赖,并将结果打包成一个fat jar。 2. **使用Gradle Shadow Plugin**: 对于使用Gradle的项目,Shadow Plugin是实现fat jar打包的首选。与...
聚合项目可以将多个模块组合成一个整体进行构建,而profiles可以根据不同环境(如开发、测试、生产)设置不同的配置,实现灵活的部署策略。 总之,Maven通过标准化的构建流程和强大的依赖管理,极大地提高了Java...
为了解决这个问题,我们需要将其打包成一个“胖JAR”(Fat Jar),它包含所有依赖库,并且能够像Windows上的EXE文件一样直接运行。本文将详细介绍如何打包JAR并创建可以直接运行的Java EXE文件。 首先,理解JAR文件...
Assembly 是一个基于 Maven 的插件,用于将项目的依赖项和资源文件打包成一个可执行的文件,例如 zip、tar.gz 等。Assembly 可以帮助开发者方便地将项目打包成一个独立的文件,使得项目的部署和分发变得更加方便。 ...
可以使用Maven或Gradle这样的构建工具,通过配置pom.xml或build.gradle文件,设置相关的打包插件(如maven-assembly-plugin或shadow插件),将所有依赖合并到一个jar中。打包后的single_jar文件应包含所有类和配置...
通过在`pom.xml`(Maven)或`build.gradle`(Gradle)文件中配置插件,我们可以将项目打包成一个独立的可执行JAR或WAR文件。对于生成独立JAR,Maven可以使用`spring-boot-maven-plugin`,Gradle则有`bootJar`任务。...
9. **其他打包工具对比**:Fat Jar与其他打包工具(如Apache Maven的assembly插件或shade插件)相比,可能在自动化和灵活性上稍显不足,但在简单的项目中,其易用性是一个很大的优点。 10. **持续集成**:如果你的...
"fatjar"的创建通常需要用到特定的打包工具,如Apache Maven的maven-assembly-plugin或maven-shade-plugin,或者Gradle的shadow插件。 "GPL.txt"、"changes.txt"和"readme.txt"是常见的文档文件。"GPL.txt"可能包含...
这可以通过设置`--jars`选项来实现,或者在使用`spark-submit`命令时指定`--class`和`--assembly-jar`参数,如果你已经将所有依赖项打包成一个fat jar。 6. **集群环境的Scala版本**:在分布式环境中,集群的每个...
为了将所有这些内容打包成一个ZIP文件,我们需要使用`maven-assembly-plugin`或`maven-shade-plugin`。这里我们将使用`maven-assembly-plugin`,它允许我们创建自定义的打包格式。在`<plugins>`节点中添加以下配置:...