Maven知识点记录 – profile
最后更新于:2022-04-01 20:45:13
在实际开发过程中,开发环境,测试环境和最后部署上线的环境都是不一样的,像数据库连接,都是要变的。
如果不使用Maven的话,我想到的就是修改配置文件,手动的修改;
使用Maven的话,就简单的多了。
先来看一个pom文件:
~~~
4.0.0
org.ygy
maven
war
0.0.1-SNAPSHOT
maven Maven Webapp
http://maven.apache.org
UTF-8
devlopment
lufei
shishi
src/main/resources
true
true
test
http://www.deppon.com
haha
can you
src/main/resources
true
false
junit
junit
4.10
test
org.springframework
spring-core
3.1.1.RELEASE
org.springframework
spring-beans
3.1.1.RELEASE
org.springframework
spring-context
3.1.1.RELEASE
org.springframework
spring-jdbc
3.1.1.RELEASE
maven
~~~
其中,有些标签可能没有用过,就是,
Profile 的作用是允许你在项目文件(pom.xml)里定义若干个 profile 段,然后在编译时选择其中的一个用于覆盖项目文件原先的定义。
~~~
devlopment
lufei
shishi
src/main/resources
true
true
~~~
我们大体上可以看懂,下面简单介绍一下具体的用法:
1.activation 激活方式
1)根据环境自动激活:如可以根据JDK版本,OS,Maven属性来激活
~~~
dev
false
1.5
Windows XP
Windows
x86
5.1.2600
mavenVersion
2.0.5
file2.properties
file1.properties
...
~~~
2)通过命令行激活
这是最直接和最简单的方式,比如你定义了一个名为 myProfile 的 profile,你只需要在命令行输入 mvn clean install -P myprofile 就能将其激活,
这种方式的好处很明显,但是有一个很大的弊端,当 profile 比较多的时候,在命令行输入这写 -P 参数会让人觉得厌烦,
所以,如果你一直用这种方式,觉得厌烦了,可以考虑使用其它自动激活的方式。
3)配置默认自动激活
~~~
dev
true
...
~~~
4)配置 settings.xml 文件 profile 激活
settings.xml 文件可以在 ~/.m2 目录下,为某个用户的自定义行为服务,也可以在 M2_HOME/conf 目录下,为整台机器的所有用户服务。
而前者的配置会覆盖后者。同理,由 settings.xml 激活的 profile 意在为用户或者整个机器提供特定环境配置,
比如,你可以在某台机器上配置一个指向本地数据库 URL 的 profile,然后使用该机器的 settings.xml 激活它。激活方式如下:
~~~
...
local_db
~~~
(注:参考博客 [激活Maven profile的几种方式](http://juvenshun.iteye.com/blog/208714))
2.filtering功能
这里的意思是,过滤src/main/resources下的文件
~~~
src/main/resources
true
~~~
Filtering 是 Maven Resources Plugin 的一个功能,它会使用系统属性或者项目属性的值替换资源文件(*.properties,*.xml)当中 ${…} 符号的值。
比如你系统属性有一项 “user.name=foobar”,那么资源文件当中的 ${user.name} 符号会在 Maven 编译时自动被替换为 “foobar”。
(注:参考博客 [Apache Maven 使用 profile 和 filtering 实现多种环境下的资源](http://archboy.org/2012/05/21/apache-maven-profile-filtering-multiple-build-environments/))
Maven官方Filter讲解:[http://maven.apache.org/plugins/maven-resources-plugin/examples/filter.html](http://maven.apache.org/plugins/maven-resources-plugin/examples/filter.html)
3.说了这么多,下面来实践一下
这是我们的Maven项目:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-09-06_57ce64fe9fc91.jpg)
一个是配置文件,一个是Spring的配置文件
demo.properties
~~~
hello ,${username}
jdbc.url = ${jdbc.url}
jdbc.username = ${jdbc.username}
jdbc.password = ${jdbc.password}
~~~
applicationContext.xml
~~~
~~~
pom.xml就是最上面提到的:
~~~
4.0.0
org.ygy
maven
war
0.0.1-SNAPSHOT
maven Maven Webapp
http://maven.apache.org
UTF-8
devlopment
lufei
shishi
src/main/resources
true
true
test
http://www.deppon.com
haha
can you
src/main/resources
true
false
junit
junit
4.10
test
org.springframework
spring-core
3.1.1.RELEASE
org.springframework
spring-beans
3.1.1.RELEASE
org.springframework
spring-context
3.1.1.RELEASE
org.springframework
spring-jdbc
3.1.1.RELEASE
maven
~~~
这里有2个profile,一个是development,一个是test,默认自动激活development
注意
~~~
lufei
shishi
~~~
~~~
索隆
gogo
http://www.deppon.com
haha
can you
~~~
这里的和就是我们在配置文件中使用的会变化的配置,Maven会自动将 ${}替换成profile中配置的。
接下来,我们进入到该项目的根目录下,执行Maven命令
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-09-06_57ce64feba9f3.jpg)
1.使用默认激活方式
~~~
mvn clean compile
~~~
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-09-06_57ce64fed6f71.jpg)
进入target/classes目录
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-09-06_57ce64feefe6b.jpg)
打开demo.properties和applicationContext.xml文件
会发现,在development中指定的属性都已经成功替换
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-09-06_57ce64ff11090.jpg)
而demo.properties中,jdbc相关的并没有配置,所以没有替换
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-09-06_57ce64ff2836d.jpg)
2.使用命令更改激活方式
重新输入命令
~~~
mvn clean compile -P test
~~~
我们启用了test环境的配置方式
再次进入target/classes文件夹下查看,会发现不同的替换
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-09-06_57ce64ff40a8f.jpg)
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-09-06_57ce64ff5684f.jpg)
好了,到这里就可以简单使用了。
';