开发工具:Intellij IDEA。
项目框架:SpringMvc
技术:Maven Profile
项目目录:
manager是聚合工程,剩下的manager-*是模块,其中manager-web打包方式是war。
动态发布配置在manager-web中进行,不涉及其他项目或者模块。
例一:动态配置数据库源。
目录:
其中,数据库信息位于config下,配置入口是jdbc.properties,在applicationContext-dao.xml中进行配置。
pom.xml中需要添加三处内容
内容一:在manager-web的pom.xml的根节点下添加profiles标签(和build,dependencies标签平级)
<profiles>
<profile>
<!-- 发布环境 -->
<id>pro</id>
<properties>
<profiles.active>pro</profiles.active>
</properties>
</profile>
<profile>
<!-- 测试环境 -->
<id>beta</id>
<properties>
<profiles.active>beta</profiles.active>
</properties>
<activation>
<!-- 设置默认激活这个配置 -->
<activeByDefault>true</activeByDefault>
</activation>
</profile>
</profiles>
内容二:在build节点下,添加filters和resources节点
<finalName>ROOT</finalName>
<!-- 定义了变量配置文件的地址 -->
<filters>
<filter>src/main/resources/config/jdbc-${profiles.active}.properties</filter>
</filters>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
finalName是命名war包的名字。
内容三:在build的plugins节点下添加plugin节点。
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
</plugin>
pom.xml内容结束。
properties文件的文件名和内容。
config下的propertis文件命名规则:jdbc-XXX.properties
XXX对应pom.xml中的profiles.active节点。
例如jdbc-beta.properties的内容为:
env.datasource.driver=com.microsoft.sqlserver.jdbc.SQLServerDriver
env.datasource.jdbcUrl=jdbc:sqlserver://localhost:1433;DatabaseName=master
env.datasource.username=sa
env.datasource.password=123456
#定义初始连接数
initialSize=0
#定义最大连接数
maxActive=20
#定义最大空闲
maxIdle=20
#定义最小空闲
minIdle=1
#定义最长等待时间
maxWait=60000
jdbc-pro.properties的内容对应生产环境的内容,格式与
jdbc-beta.properties类似,换成生产环境的数据源即可。
properties文件夹下的jdbc.properties文件内容为:
datasource.driver=${env.datasource.driver}
datasource.jdbcUrl=${env.datasource.jdbcUrl}
datasource.username=${env.datasource.username}
datasource.password=${env.datasource.password}
#定义初始连接数
initialSize=0
#定义最大连接数
maxActive=20
#定义最大空闲
maxIdle=20
#定义最小空闲
minIdle=1
#定义最长等待时间
maxWait=60000
properties配置完成。
applicationContext-dao.xml相关配置:
<context:property-placeholder location="classpath:properties/*.properties" />
<!-- 数据库连接池 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
destroy-method="close">
<property name="url" value="${datasource.jdbcUrl}" />
<property name="username" value="${datasource.username}" />
<property name="password" value="${datasource.password}" />
<property name="driverClassName" value="${datasource.driver}" />
<property name="maxActive" value="10" />
<property name="minIdle" value="5" />
</bean>
使用context:property-placeholder读取jdbc.properties文件(相当于将项目config路径下的两个properties的内容动态的注入jdbc.properties)。
数据源动态配置完成。
打包
动态打包命令:mvn clean install -PXXX
XXX的内容是pom.xml中的profiles.active节点的内容。
例如测试环境打包,则命令为
mvn clean install -Pbata
检测是否打包成功:war包解压后,查看jdbc.properties内容是否替换为环境对应的config下的properties文件内容。