環境配置
在你的 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 即可。