您的位置:首页 > 编程语言 > Java开发

Maven多模块项目动态打包(SpringMVC数据源动态配置)

2018-01-20 11:21 519 查看
开发工具: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文件内容。


                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息