Spring Profile基本使用

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

阅读更多
换一批

没有更多推荐了,返回首页