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。
热门文章
- 「2月22日」最高速度19.6M/S,2025年Clash Nyanpasu每天更新免费节点订阅链接
- Java程序来删除一个文件中的某些文本
- 重庆宠物领养中心地址在哪里啊电话(重庆宠物领养重庆宠物赠送)
- vue 详情页返回列表,过滤查询条件保留
- 广州宠物领养网免费吗多少钱(广州宠物狗领养网站)
- 「1月13日」最高速度20.4M/S,2025年Clash Nyanpasu每天更新免费节点订阅链接
- 「3月1日」最高速度19.3M/S,2025年Clash Nyanpasu每天更新免费节点订阅链接
- 「2月13日」最高速度20.7M/S,2025年Clash Nyanpasu每天更新免费节点订阅链接
- 合肥宠物猫领养中心地址电话(合肥宠物猫领养中心地址电话查询)
- 宠物领养协议模板图片 宠物领养协议模板图片大全