环境配置
在你的 pom.xml 文件中添加如下配置:
<
profiles
>
< profile > <!-- 可以通过 -P ID 来激活 -->
< id >PROD </ id > <!-- ID 标识符 -->
< properties >
< env >PROD </ env > <!-- properties 定义 key-value, 这里 key 是 env, value 是 PROD -->
</ properties >
< activation >
< activeByDefault >true </ activeByDefault > <!-- 默认激活 -->
</ activation >
</ profile >
< profile > <!-- 可以通过 -P ID 来激活 -->
< id >TEST </ id > <!-- ID 标识符 -->
< properties >
< env >TEST </ env > <!-- properties 定义 key-value, 这里 key 是 env, value 是 TEST -->
</ properties >
</ profile >
</ profiles >
上面定义了两套环境的配置,一套是用于生产环境的 PROD,另外一套是用于测试环境的 TEST。profile 可以通过 -P 参数来激活,如 -PTEST
< profile > <!-- 可以通过 -P ID 来激活 -->
< id >PROD </ id > <!-- ID 标识符 -->
< properties >
< env >PROD </ env > <!-- properties 定义 key-value, 这里 key 是 env, value 是 PROD -->
</ properties >
< activation >
< activeByDefault >true </ activeByDefault > <!-- 默认激活 -->
</ activation >
</ profile >
< profile > <!-- 可以通过 -P ID 来激活 -->
< id >TEST </ id > <!-- ID 标识符 -->
< properties >
< env >TEST </ env > <!-- properties 定义 key-value, 这里 key 是 env, value 是 TEST -->
</ properties >
</ profile >
</ profiles >
(或 -P TEST)即可激活 TEST 配置。TEST 配置激活之后,通过 ${env} 表达式即可获得 <env>TEST</env> 配置的 TEST 字符串值。
assembly 插件
maven-assembly-plugin 插件可以实现自定义打包。在你的 pom.xml 文件中添加如下配置:
<
build
>
< plugins >
< plugin >
< artifactId >maven-assembly-plugin </ artifactId > <!-- 官网给出的配置,没有配置 groupId,这里也不配置 -->
< version >2.4 </ version >
< executions >
< execution >
< id >make-assembly </ id > <!-- ID 标识,命名随意 -->
< phase >package </ phase > <!-- 绑定到 PACKAGE 生命周期阶段 -->
< goals >
< goal >single </ goal > <!-- 在 PACKAGE 生命周期阶段仅执行一次 -->
</ goals >
</ execution >
</ executions >
< configuration >
< descriptors >
< descriptor >assembly.xml </ descriptor > <!-- 自定义打包的配置文件 -->
</ descriptors >
< appendAssemblyId >false </ appendAssemblyId > <!-- 设为 FALSE, 防止 WAR 包名加入 assembly.xml 中的 ID -->
</ configuration >
</ plugin >
</ plugins >
</ build >
在项目的根目录下创建一个 assembly.xml 文件(与 pom.xml 文件在同一个目录)。示例项目的结构如下:
< plugins >
< plugin >
< artifactId >maven-assembly-plugin </ artifactId > <!-- 官网给出的配置,没有配置 groupId,这里也不配置 -->
< version >2.4 </ version >
< executions >
< execution >
< id >make-assembly </ id > <!-- ID 标识,命名随意 -->
< phase >package </ phase > <!-- 绑定到 PACKAGE 生命周期阶段 -->
< goals >
< goal >single </ goal > <!-- 在 PACKAGE 生命周期阶段仅执行一次 -->
</ goals >
</ execution >
</ executions >
< configuration >
< descriptors >
< descriptor >assembly.xml </ descriptor > <!-- 自定义打包的配置文件 -->
</ descriptors >
< appendAssemblyId >false </ appendAssemblyId > <!-- 设为 FALSE, 防止 WAR 包名加入 assembly.xml 中的 ID -->
</ configuration >
</ plugin >
</ plugins >
</ build >
不管是开发环境、测试环境还是生产环境等,它们通常只是配置文件不一样,下面实现根据不同的参数打包出适应各个不同环境的 WAR 包。
assembly.xml 配置
assembly.xml 文件的配置如下:
<
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" >
<!-- ID 标识,命名随意 -->
< id >${project.artifactId}-assembly-${project.version} </ id >
<!-- 默认为 TRUE, 设为 FALSE, 防止将 ${project.finalName} 作为根目录打进 WAR 包 -->
<!-- TRUE 结构: ${project.finalName}.war/${project.finalName}/WEB-INF -->
<!-- FALSE 结构: ${project.finalName}.war/WEB-INF -->
< includeBaseDirectory >false </ includeBaseDirectory >
<!-- 设置为 WAR 包格式 -->
< formats >
< format >war </ format >
</ formats >
< fileSets >
<!-- 将 target/classes 下的文件输出到 WEB-INF/classes, 同时排除 target/classes/conf/*.properties -->
< fileSet >
< directory >${project.build.outputDirectory} </ directory > <!-- target/classes -->
< outputDirectory >WEB-INF/classes </ outputDirectory >
< excludes >
< exclude >**/conf/*.properties </ exclude >
</ excludes >
</ fileSet >
<!-- 将 env/${env}/conf 下的文件输出到 WEB-INF/classes/conf, 实现 -P 不同的参数打包出不同的配置 -->
<!-- ${env} 的值由 -P 的参数传递进来, 如:-PTEST, 那么, ${env} 的值就是 TEST -->
< fileSet >
< directory >${project.basedir}/env/${env}/conf </ directory >
< outputDirectory >WEB-INF/classes/conf </ outputDirectory >
</ fileSet >
<!-- 将 webapp 下的文件输出到 WAR 包 -->
< fileSet >
< directory >${project.basedir}/src/main/webapp </ directory >
< outputDirectory >/ </ outputDirectory >
</ fileSet >
</ fileSets >
<!-- 将项目依赖的JAR包输出到 WEB-INF/lib -->
< dependencySets >
< dependencySet >
< outputDirectory >WEB-INF/lib </ outputDirectory >
</ dependencySet >
</ dependencySets >
</ assembly >
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" >
<!-- ID 标识,命名随意 -->
< id >${project.artifactId}-assembly-${project.version} </ id >
<!-- 默认为 TRUE, 设为 FALSE, 防止将 ${project.finalName} 作为根目录打进 WAR 包 -->
<!-- TRUE 结构: ${project.finalName}.war/${project.finalName}/WEB-INF -->
<!-- FALSE 结构: ${project.finalName}.war/WEB-INF -->
< includeBaseDirectory >false </ includeBaseDirectory >
<!-- 设置为 WAR 包格式 -->
< formats >
< format >war </ format >
</ formats >
< fileSets >
<!-- 将 target/classes 下的文件输出到 WEB-INF/classes, 同时排除 target/classes/conf/*.properties -->
< fileSet >
< directory >${project.build.outputDirectory} </ directory > <!-- target/classes -->
< outputDirectory >WEB-INF/classes </ outputDirectory >
< excludes >
< exclude >**/conf/*.properties </ exclude >
</ excludes >
</ fileSet >
<!-- 将 env/${env}/conf 下的文件输出到 WEB-INF/classes/conf, 实现 -P 不同的参数打包出不同的配置 -->
<!-- ${env} 的值由 -P 的参数传递进来, 如:-PTEST, 那么, ${env} 的值就是 TEST -->
< fileSet >
< directory >${project.basedir}/env/${env}/conf </ directory >
< outputDirectory >WEB-INF/classes/conf </ outputDirectory >
</ fileSet >
<!-- 将 webapp 下的文件输出到 WAR 包 -->
< fileSet >
< directory >${project.basedir}/src/main/webapp </ directory >
< outputDirectory >/ </ outputDirectory >
</ fileSet >
</ fileSets >
<!-- 将项目依赖的JAR包输出到 WEB-INF/lib -->
< dependencySets >
< dependencySet >
< outputDirectory >WEB-INF/lib </ outputDirectory >
</ dependencySet >
</ dependencySets >
</ assembly >
打包出适应各个环境的 WAR 包
选中项目右键 --> Run As --> Maven build... --> Goals 栏输入 -PTEST clean package 。执行完成即可打包出测试环境的 WAR 包(示例源码下载: proj-web.zip )。
你可以将打包出来的 WAR 包重命名为 ROOT.war,然后把它丢到 Tomcat 的 webapps 目录下,备份删除 ROOT 文件夹,启动/重启 Tomcat 即可。