maven+myeslipse 多环境打包

来源:互联网 发布:手机淘宝设置关联购买 编辑:程序博客网 时间:2024/05/01 16:15

我们经常需求对不同的环境打不同的包

比如,测试环境包,线上环境包

这意味着不同的环境,配置参数不同,同时我们还想对打包的包名进行个性化命名

所以我们就逐步讲解利用maven进行这种需求的打包

1.pom.xml的profile配置

<profile>标签允许我们进行不同环境的参数配置,例如下面这段配置代码

<profiles>        <profile>            <id>test</id>            <activation>                <activeByDefault>true</activeByDefault>            </activation>            <properties>                <!-- mysql -->                <p.jdbc.url>127.0.0.1:3306</p.jdbc.url>                <p.jdbc.dbname>test_trunk</p.jdbc.dbname>                <p.jdbc.username>root</p.jdbc.username>                <p.jdbc.password>123456</p.jdbc.password>                           <!--包名后缀-->                <p.package.suffix>test</p.package.suffix>            </properties>        </profile>        <profile>            <id>production</id>            <properties>                <!-- mysql -->                <p.jdbc.url>10.5.121.186:23325</p.jdbc.url>                <p.jdbc.dbname>db_prod</p.jdbc.dbname>                <p.jdbc.username>root</p.jdbc.username>                <p.jdbc.password>root</p.jdbc.password>                <!--包名后缀-->                <p.package.suffix>prod</p.package.suffix>            </properties>        </profile></profiles>

上面的配置是对不同环境数据库的配置,以及包名后缀进行了属性配置,并且对打包的输出包名的后缀进行了个性化的配置。

对于profile标签,我们还需要有个.properties文件,持有这些变量,例如:config.properties

jdbc.driverClassName=com.mysql.jdbc.Driverjdbc.url=jdbc\:mysql\://${p.jdbc.url}/${p.jdbc.dbname}?useUnicode\=true&characterEncoding\=UTF-8&zeroDateTimeBehavior\=convertToNull&rewriteBatchedStatements\=truejdbc.username=${p.jdbc.username}jdbc.password=${p.jdbc.password}

这样,在我们的进行applicationContext.xml文件配置的时候,就可以使用这些变量了,使用方法如下(与spring结合):

  <context:property-placeholder location="classpath:/config.properties" />  <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">       <property name="driverClass" value="${jdbc.driverClassName}" />    <property name="jdbcUrl" value="${jdbc.url}" />    <property name="user" value="${jdbc.username}" />    <property name="password" value="${jdbc.password}" />  </bean>

在打包的时候,我们可以利用maven-war-plugin这个插件,进行个性化的打包

Myeclipse中,工程项目的输出路径一般是src/main/webapp/WEB-INF/classes下,即myeclipse的编译输出路径

但是maven的默认输出路径是target/ 下,约定优于配置原则。

在打包的时候,maven是需要从src/main/webapp 下Copying webapp resources

但是刚才提到的config.properties经过myeclipse的编译,变量并没有替换,只要经过了maven命令的编译,才会在target/classes下出现真正需要的config.properties的文件。

所以我们的打包插件需要做如下配置:

在<properties>标签下新增如下配置<maven.build.timestamp.format>yyyyMMddHHmm</maven.build.timestamp.format>            在build标签的plugins标签下添加这样的配置<plugin>    <groupId>org.apache.maven.plugins</groupId>    <artifactId>maven-war-plugin</artifactId>    <version>2.4</version>     <configuration>        <warSourceExcludes>**/*.properties</warSourceExcludes>        <warName>${project.artifactId}-${p.package.suffix}-${maven.build.timestamp}-${project.version}</warName>    </configuration></plugin>

这样,在打包的时候,避免从src/main/webapp拷贝.properties文件,同时打包后的包名也有很强的识别性,类似如下结果

showcasename-prod-201411210911-1.3.0-SNAPSHOT.war


执行maven命令 进行编译

mvn clean package -P production  (打生产环境包)

mvn clean package -P test(打测试环境包)

-P后的参数与profile的id值一致



0 0
原创粉丝点击