Spring Profile基本使用

来源:互联网 发布:灰色关联分析法 编程 编辑:程序博客网 时间:2024/04/29 21:28

Spring profile是Spring 3引入的概念,一般系统开发的时候更喜欢使用Maven中的profile来进行不同环境配置文件的区分。Spring的profile一直没有怎么使用,最近在一个公司系统开发过程中同事使用了Spring profile。可是在设置default profile上遇到了麻烦。跟着一起研究了半天,才发现了问题所在。

Spring profile在我们系统中的使用非常简单,并没有使用runtime的特性,只是在xml中定义了不同profile环境中的beans

<!-- other beans -->    <bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean"/>    .......    <!-- production环境 -->    <beans profile="production">        <context:property-placeholder ignore-resource-not-found="true"            location="classpath*:/application.properties" />        ....    </beans>    <!-- local环境 -->    <beans profile="local">        <context:property-placeholder ignore-resource-not-found="true"            location="classpath*:/application.properties            ,classpath*:/application.development.properties"/>      ....    </beans>

接下来我们一般可以通过在web.xml,在properties中来选择使用什么环境的profile,例如

    <!-- web.xml -->    <context-param>            <param-name>spring.profiles.default</param-name>            <param-value>production</param-value>    </context-param>    <!-- properties选择 -->    System.setProperty("spring.profiles.active", "development");

我们的问题出在哪里呢?出在了我们想通过jndi而不是jvm参数来选择默认的profile,首先我们知道spring profile的设置不能在properties文件里,因为spring的加载顺序。我们不想改变系统的启动参数,所以选择了jndi的方式来读取profile的默认启动,关键来了,在配置jndi的时候我们进行了以下设置

 <Environment name="spring.profiles.active" type="java.lang.String" value="local">

悲哀的发现不起作用,spring的log里面也没有任何有用的提示,还没到获取profile相关的log就因为读取不到bean挂了。只好去掉了profile相关的xml文件重启启动一次系统才发现spring默认读取的jndi名字是spring.profiles.default而不是spring.profiles.active

1 0
原创粉丝点击