简单的说,maven-assembly-plugin 就是用来帮助打包用的,比如说打出一个什么类型的包,包里包括哪些内容等等。
maven插件是在生命周期中某些阶段执行的任务。一个插件完成一项功能。以下介绍几种常见的插件。
如对于打包来说,有多种插件选择。最常见的有以下3个:
plugin | function |
---|---|
maven-jar-plugin |
maven 默认打包插件,用来创建 project jar |
maven-shade-plugin |
用来打可执行包,executable(fat) jar |
maven-assembly-plugin |
支持定制化打包方式,例如 apache 项目的打包方式 |
以下选取几个常见插件介绍。
编译Java源码,一般只需设置编译的jdk版本
org.apache.maven.plugins
maven-compiler-plugin
3.6.0
1.8
或者在properties设置jdk版本
UTF-8
1.8
1.8
打成jar时,设定manifest的参数,比如指定运行的Main class,还有依赖的jar包,加入classpath中
org.apache.maven.plugins
maven-jar-plugin
2.4
true
/data/lib
com.zhang.spring.App
用于远程部署Java Web项目
org.apache.tomcat.maven
tomcat7-maven-plugin
2.2
http://59.110.162.178:8080/manager/text
linjinbin
linjinbin
用于把多个jar包,打成1个jar包
一般Java项目都会依赖其他第三方jar包,最终打包时,希望把其他jar包包含在一个jar包里。
与assembly类似,使用assembly即可。以下详解assembly。
1.首先我们需要在pom.xml中配置maven的assembly插件
org.apache.maven.plugins
maven-assembly-plugin
make-assembly
package
(1)
single
(2)
${project.name}
...
src/main/assembly/assembly.xml
2.两个主要的参数设置(上述中的(1)(2))
可以执行如下命令完成动作:
mvn assembly:single
或者是,绑定到package生命周期阶段上(见上配置)触发。后续可以直接执行:
mvn package
这也是最常见的Assembly插件配置方式。
Assembly Descriptor可以使用内置的,或者定制的。
(1) 使用内置的Assembly Descriptor
要使用maven-assembly-plugin,需要指定至少一个要使用的assembly descriptor 文件。默认情况下,maven-assembly-plugin内置了几个可以用的assembly descriptor:
使用 descriptorRefs来引用(官方提供的定制化打包方式)【不建议使用】
maven-assembly-plugin
jar-with-dependencies
上述直接配置jar-with-dependencies
打包方式。不需要引入额外文件。实际上,上述4中预定义的assembly descriptor有对应的xml。要查看它们的详细定义,可以到maven-assembly-plugin.jar里去看,例如对应 bin 的assembly descriptor 原始文件如下:
bin
tar.gz
tar.bz2
zip
${project.basedir}
/
README*
LICENSE*
NOTICE*
${project.build.directory}
/
*.jar
${project.build.directory}/site
docs
(2) 自定义Assembly Descriptor
一般来说,内置的assembly descriptor都不满足需求,这个时候就需要写自己的assembly descriptor的实现了。
使用 descriptors
,指定打包文件 src/assembly/assembly.xml
,即在配置文件内指定打包操作要使用这个自定义assembly descriptor(自定义的xml中配置),需要如下配置,即要引入描述文件:
demo
src/assembly/assembly.xml
output
示例:src/assembly/assembly.xml
:
demo
jar
false
${project.build.directory}/classes
/
这个定义很简单:
回到pom的配置中,自定义的configuration配置后,将会生成一个demo-demo.jar
文件在目录 output
下,其中前一个demo
来自finalName
,后一个demo
来自assembly descriptor中的id
,其中的内容和默认的打包出来的jar类似。
如果只想有finalName,则增加配置:
false
对于描述文件的元素,即assembly.xml中的配置节点的详细配置,在此稍作总结,见下。
在配置assembly.xml之前,我们先看一下pom中引入插件的结构。
[...]
[...]
------------(1)坐标-----------
maven-assembly-plugin
3.0.0
------------(2)入口-----------
true
com.***.startup.BootStrap
------------(3)描述-----------
src/assembly/assembly.xml
[...]
archive说明
上面的mainClass
标签中的内容替换成自己的main
函数所在的类,前面要包含package
名字,也就是package_name.MainClassName
。
assembly.xml文件的主要结构如下。
id
distribution
id 标识符,添加到生成文件名称的后缀符。如果指定 id 的话,目标文件则是 ${artifactId}-${id}.tar.gz
formats
maven-assembly-plugin 支持的打包格式有zip、tar、tar.gz (or tgz)、tar.bz2 (or tbz2)、jar、dir、war,可以同时指定多个打包格式
dir
dependencySets
用来定制工程依赖 jar 包的打包方式,核心元素如下表所示。
元素 | 类型 | 作用 |
---|---|---|
outputDirectory | String | 指定包依赖目录,该目录是相对于根目录 |
includes | List |
包含依赖 |
excludes | List |
排除依赖 |
/lib
${project.groupId}:${project.artifactId}
/
${project.groupId}:${project.artifactId}
fileSets
管理一组文件的存放位置,核心元素如下表所示。
元素 | 类型 | 作用 |
---|---|---|
outputDirectory | String | 指定文件集合的输出目录,该目录是相对于根目录 |
includes | List |
包含文件 |
excludes | List |
排除文件 |
fileMode | String | 指定文件属性,使用八进制表达,分别为(User)(Group)(Other)所属属性,默认为 0644 |
shell
/shell
cluster_config
/cluster_config
其他
其他的,如files节点基本类似fileSets。不常用的暂不介绍。
至此,即可按打包成功。下边给出具体示例。
本文学习目标:
mybatis-generator-plus
插件的源码(中文注释、4格缩进,简化生成文件个数);pom.xml
pro-all
cn.whbing.pro
1.0-SNAPSHOT
4.0.0
mybatis-genarator-modify
log4j
log4j
1.2.17
org.apache.ant
ant
1.9.1
mybatis-genarator-modify
src/main/resources
**/*.properties
**/*.xml
**/*.tld
**/*.dtd
false
src/main/java
**/*.properties
**/*.xml
**/*.tld
**/*.dtd
false
org.apache.maven.plugins
maven-assembly-plugin
2.6
mybatis-genarator-modify
jar-with-dependencies
true
org.mybatis.generator.api.ShellRunner
make-assembly
package
single
运行命令后,在target目录下生成了文件:
将上述jar
包复制到测试文件夹中,将generatorConfig.xml
文件也复制过来:
其中generatorConfig.xml
文件:
可以看到成功生成文件
执行命令:
java -jar mybatis-genarator-modify-jar-with-dependencies.jar -configfile generatorConfig.xml