开发需求:在日常开发中,我们大多都会有开发环境(dev)、测试环境(test)、生产环境(product),不同环境的参数肯定不一样,我们需要在打包的时候,不同环境打不同当包,如果手动改,一方面效率低,容易出错,而且每次打包都改动,麻烦,所以Maven给我们提供了profile的配置
先贴一段代码,然后后面讲一些概念
1、首先需求就是有三个环境,每个环境的配置参数不一样,希望在打包的时候,不同环境用的配置数据不一样
2、配置文件
dev
#这是dev环境配置 jdbc_url=jdbc:mysql://127.0.0.1:3306/abcdev jdbc_user=root jdbc_password=root
test
#这是test环境配置 jdbc_url=jdbc:mysql://192.168.1.180:3306/abcdev jdbc_user=test_user jdbc_password=test_password
product
#这是product环境配置 jdbc_url=jdbc:mysql://10.6.8.30:3306/abcdev jdbc_user=product_user jdbc_password=product_password
下面是spring 数据库连接配置中一段代码,其中数据库连接url, username, password用${key}这种方式
<!-- 创建数据库连接 -->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
<!-- 数据库驱动 -->
<!-- 基本属性 url、user、password -->
<property name="url" value="${jdbc_url}" />
<property name="username" value="${jdbc_user}" />
<property name="password" value="${jdbc_password}" />
<!-- 配置初始化大小、最小、最大 -->
<property name="initialSize" value="1" />
<property name="minIdle" value="1" />
<property name="maxActive" value="20" />
<!-- 配置获取连接等待超时的时间 -->
<property name="maxWait" value="60000" />
<!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
<property name="timeBetweenEvictionRunsMillis" value="60000" />
<!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
<property name="minEvictableIdleTimeMillis" value="300000" />
<property name="validationQuery" value="SELECT 'x'" />
<property name="testWhileIdle" value="true" />
<property name="testOnBorrow" value="false" />
<property name="testOnReturn" value="false" />
<!-- 打开PSCache,并且指定每个连接上PSCache的大小 -->
<property name="poolPreparedStatements" value="true" />
<property name="maxPoolPreparedStatementPerConnectionSize" value="20" />
<!-- 配置监控统计拦截的filters -->
<property name="filters" value="stat" />
</bean>
3、pom一些配置
<profiles> <profile> <id>dev</id> <properties> <profiles.active>dev</profiles.active> </properties> <activation> <activeByDefault>true</activeByDefault> </activation> <build> <filters> <filter>src/main/resources/dev.properties</filter> </filters> </build> </profile> <profile> <id>test</id> <properties> <profiles.active>test</profiles.active> </properties> <build> <filters> <filter>src/main/resources/test.properties</filter> </filters> </build> </profile> <profile> <id>prod</id> <properties> <profiles.active>prod</profiles.active> </properties> <build> <filters> <filter>src/main/resources/prod.properties</filter> </filters> </build> </profile> </profiles>
<build> <finalName>myweb</finalName> <resources> <resource> <directory>src/main/resources</directory> <includes> <include>**/*</include> </includes> <filtering>true</filtering> <excludes> <exclude>application-text.xml</exclude> <!--<exclude>src/main/resources/application-text.xml</exclude>--> </excludes> </resource> </resources> <!--<filters>--> <!--<filter>src/main/resources/${profiles.active}.properties</filter>--> <!--</filters>--> </build>
4、最终,执行一个命令,mvn clean package ,我们看下编译后target下面的采用${key}有没有替换
我们看到已经替换为dev的数据库连接,如果想打test的包呢,很简单: mvn clean package -Ptest
好,到此为止,满足了我们的一个基本需求,我们来重点看看pom中的上面贴的配置
分析profile相关概念
1、profiles:定义各个环境的变量配置,我上面的代码中有三个环境,所以配了3个profile
<id>:profile的标示
<properties>:自己定义的一些属性,可有可无,比如我配置的jdbc.url这些属性,如果不想通过properties定义这些,可以在改属性下面配置
<filters>比较重要,指定当前profile环境下,属性文件路径;
分析build下属性
我们分析下<resource>下面的属性
<directory>: 配置那个目录下的文件通过${key}会被替换成属性值,resource目录下,我们一般放jdbc连接,或配置文件
<includes>:指定那个目录下那个文件
<filtering>:这个配置的意思是过滤上面指定属性文件中的占位符,占位符是${变量名称}这样的形式,maven会自动读取配置文件,然后解析其中的占位符,使用上面pom文件中定义的属性进行替换
<exclueds>:在resource目录下,有很多文件,但用些文件不希望替换,则可以通过<excluede>指定
<filters>:这里的filters与<profile>的filter意思一样,都是指属性文件地址,这个如果上面定义<profile>的时候指定了,这里就不需要了,但有些开发习惯是在<profile>不定义,然后在<build>里指定。
好了,只有简单配置这些,在使用maven命令的时候 mvn clean package -PprofileId ,就可以根据不同环境打不同的包了