在实际开发过程中,开发环境,测试环境和最后部署上线的环境都是不一样的,像数据库连接,都是要变的。
如果不使用Maven的话,我想到的就是修改配置文件,手动的修改;
使用Maven的话,就简单的多了。
先来看一个pom文件:
其中,有些标签可能没有用过,就是<profiles>,<profile>
Profile 的作用是允许你在项目文件(pom.xml)里定义若干个 profile 段,然后在编译时选择其中的一个用于覆盖项目文件原先的定义。
-
<profile>
-
<id>devlopment</id>
-
-
<properties>
-
<username>lufei</username>
-
<password>shishi</password>
-
</properties>
-
-
<build>
-
<resources>
-
<resource>
-
<directory>src/main/resources</directory>
-
<filtering>true</filtering>
-
</resource>
-
</resources>
-
</build>
-
-
<activation>
-
<activeByDefault>true</activeByDefault>
-
</activation>
-
-
</profile>
我们大体上可以看懂,下面简单介绍一下具体的用法:
1.activation 激活方式
1)根据环境自动激活:如可以根据JDK版本,OS,Maven属性来激活
-
<profile>
-
<id>dev</id>
-
<activation>
-
<activeByDefault>false</activeByDefault>
-
<jdk>1.5</jdk>
-
<os>
-
<name>Windows XP</name>
-
<family>Windows</family>
-
<arch>x86</arch>
-
<version>5.1.2600</version>
-
</os>
-
<property>
-
<name>mavenVersion</name>
-
<value>2.0.5</value>
-
</property>
-
<file>
-
<exists>file2.properties</exists>
-
<missing>file1.properties</missing>
-
</file>
-
</activation>
-
...
-
</profile>
2)通过命令行激活
这是最直接和最简单的方式,比如你定义了一个名为 myProfile 的 profile,你只需要在命令行输入 mvn clean install -P myprofile 就能将其激活,
这种方式的好处很明显,但是有一个很大的弊端,当 profile 比较多的时候,在命令行输入这写 -P 参数会让人觉得厌烦,
所以,如果你一直用这种方式,觉得厌烦了,可以考虑使用其它自动激活的方式。
3)配置默认自动激活
-
<profile>
-
<id>dev</id>
-
<activation>
-
<activeByDefault>true</activeByDefault>
-
</activation>
-
...
-
</profile>
4)配置 settings.xml 文件 profile 激活
settings.xml 文件可以在 ~/.m2 目录下,为某个用户的自定义行为服务,也可以在 M2_HOME/conf 目录下,为整台机器的所有用户服务。
而前者的配置会覆盖后者。同理,由 settings.xml 激活的 profile 意在为用户或者整个机器提供特定环境配置,
比如,你可以在某台机器上配置一个指向本地数据库 URL 的 profile,然后使用该机器的 settings.xml 激活它。激活方式如下:
-
<settings>
-
...
-
<activeProfiles>
-
<activeProfile>local_db</activeProfile>
-
</activeProfiles>
-
</settings>
(注:参考博客 激活Maven
profile的几种方式)
2.filtering功能
这里的意思是,过滤src/main/resources下的文件
-
<build>
-
<resources>
-
<resource>
-
<directory>src/main/resources</directory>
-
<filtering>true</filtering>
-
</resource>
-
</resources>
-
</build>
Filtering 是 Maven Resources Plugin 的一个功能,它会使用系统属性或者项目属性的值替换资源文件(*.properties,*.xml)当中 ${…} 符号的值。
比如你系统属性有一项 “user.name=foobar”,那么资源文件当中的 ${user.name} 符号会在 Maven 编译时自动被替换为 “foobar”。
(注:参考博客 Apache Maven 使用 profile 和 filtering 实现多种环境下的资源)
Maven官方Filter讲解:http://maven.apache.org/plugins/maven-resources-plugin/examples/filter.html
3.说了这么多,下面来实践一下
这是我们的Maven项目:
一个是配置文件,一个是Spring的配置文件
demo.properties
-
hello ,${username}
-
jdbc.url = ${jdbc.url}
-
jdbc.username = ${jdbc.username}
-
jdbc.password = ${jdbc.password}
applicationContext.xml
-
<?xml version="1.0" encoding="UTF-8"?>
-
<beans xmlns="http://www.springframework.org/schema/beans"
-
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
-
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context"
-
xsi:schemaLocation="
-
http:
-
http:
-
http:
-
http:
-
http:
-
http:
-
http:
-
http:
-
-
<bean id="simple" class="org.ygy.maven.SimpleEntity">
-
<property name="username" value="${username}"></property>
-
<property name="password" value="${password}"></property>
-
</bean>
-
</beans>
pom.xml就是最上面提到的:
这里有2个profile,一个是development,一个是test,默认自动激活development
注意
-
<properties>
-
<username>lufei</username>
-
<password>shishi</password>
-
</properties>
-
<properties>
-
<username>索隆</username>
-
<password>gogo</password>
-
<jdbc.url>http://www.deppon.com</jdbc.url>
-
<jdbc.username>haha</jdbc.username>
-
<jdbc.password>can you</jdbc.password>
-
</properties>
这里的<username>和<password>就是我们在配置文件中使用的会变化的配置,Maven会自动将 ${}替换成profile中配置的。
接下来,我们进入到该项目的根目录下,执行Maven命令
1.使用默认激活方式
进入target/classes目录
打开demo.properties和applicationContext.xml文件
会发现,在development中指定的属性都已经成功替换
而demo.properties中,jdbc相关的并没有配置,所以没有替换
2.使用命令更改激活方式
重新输入命令
-
mvn clean compile -P test
我们启用了test环境的配置方式
再次进入target/classes文件夹下查看,会发现不同的替换
好了,到这里就可以简单使用了。