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值一致
- maven+myeslipse 多环境打包
- maven 多环境打包
- maven多环境打包
- Maven-多环境打包配置
- maven多环境打包配置
- Maven Profile多环境打包
- maven auto-config 多环境自动打包
- maven+eslipse 多环境打包 profiles
- maven profile实现多环境打包
- 图解 maven 多环境打包
- Maven(spring boot)多环境打包
- maven profile实现多环境打包
- maven不同环境打包
- Eclipse+maven多环境,每个环境多配置打包
- maven 不同环境打包方案
- maven分环境打包方案
- maven根据不同环境打包
- maven 不同环境打包方案
- ActiveReports 9实战教程(2): 准备数据源(设计时、运行时)
- ie渲染模式选择
- iphone Android 联系人移植
- vs快捷建
- mysql 状态
- maven+myeslipse 多环境打包
- Jackson 框架,轻易转换JSON
- ubuntu创建wifi热点(android可识别)
- Linux安装VMWareTools
- 迄今见过的最好的职业规划文章
- Connect was not declared in this scope
- 条件表达式
- iOS:关于UITabBar的一些设置
- 2. Qt Creator 项目管理-创建项目