首页 > 学院 > 开发设计 > 正文

Spring配置文件外部化配置及.properties的通用方法

2019-11-15 01:06:34
字体:
来源:转载
供稿:网友
SPRing配置文件外部化配置及.properties的通用方法摘要:本文深入探讨了配置化文件(即.properties)的普遍应用方式。包括了Spring、一般的、远程的三种使用方案。

关键词:.properties, Spring,Disconf, java

解决问题:如何正确使用.properties配置文件。


若是有其他代码需要此Spring属性配置,将Spring配置中的属性值设置迁移到外部的属性文件中,是必需的操作,这也可以使Spring配置文件更易读。在这里我们不仅要讨论Spring的外部化配置,还要深入探讨配置化文件(即.properties)的普遍应用方式。这样就可以在不用重新打包和重新部署应用的情况下,配置这些属性值。从开发过程来看,将通用变量提出,并可配,也是写出高可读、低耦合代码的必然途径。从结果来看,这对于灵活性地进行测试、运维工作,是非常有好处的。在开发时,我们尽量把部署时需要修改的信息提出放在文件中,方便部署人员部署。一个大型系统中,多个项目有相同的配置信息,则部署人员部署时需要对多个不同的文件修改相同的信息,这不是好的代码结构,麻烦部署人员的同时,也增加了犯错的可能性。下面,就是针对以上问题的解决方案。一、原先的Spring配置 下面是普通的Spring配置文件。可以看出,这里的value可以提出,以供其它代码重用。<bean id="IndexHandler" name="IndexHandler" class="wang.anqi.util.IndexHandler"> <property name="solrUrl" value="http://192.8.125.30:8983/solr/core0"/></bean>二、经过改良后的配置1、Spring配置 下面是引入了两个配置文件db.properties和solr.properties后的Spring配置文件。<beanclass="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <propertyname="locations"> <list> <value>classpath:db.properties</value> <value>classpath:solr.properties</value> </list> </property></bean><beanid="IndexHandler"name="IndexHandler"class="wang.anqi.util.IndexHandler"> <propertyname="solrUrl"value=${solr.url}/></bean> 以下是配置文件db.propertiesdb.ip = 192.8.125.201db.name = aitanjuptdb.url = jdbc:MySQL://${db.ip}:3306/${db.name}db.username = rootdb.passWord = 1234 配置文件solr.propertiessolr.url = http://192.8.125.30:8983/solr/core02、使用@Value注解来获取配置 属性占位符配置的作用不限于xml中的Bean属性配置。还可以用它来配置@Value注解的属性。public class IndexHandler{ @Value("${solr.url}") private String solrUrl;} 然而这种方式使用起来并不十分方便。你需要先在类里面申明一个属性。3、使用ResourceBundle来读取配置
  1. privatestaticString myValue;static{try{ResourceBundle bundle =ResourceBundle.getBundle(PROPERTIES_FILE_NAME,Locale.ENGLISH);//PROPERTIES_FILE_NAME可以是solr.properties文件名的一部分:"solr"myValue = bundle.getString(MY_VALUE_KEY).trim();//MY_VALUE_KEY可以是solr.url}catch(Exception ex){System.err.println("[Property]:Can't Load property.properties");myValue ="default value";System.out.println("myValue will use the default value: "+ myValue);}}

  2. 这种方式使用起来比较方便。

三、远程读取配置文件 只是通过以上方式来管理配置,尚觉不足。在一个比较大的系统中,很有可能多个子系统都需要使用相同配置的情况,当然,你可以将这些配置记入数据库中并提供接口,自己管理起来。但是如果需要实时地将配置信息推送到不同的子系统中,情况就更将复杂了。 可以采用Disconf作为分布式配置管理平台,Disconf是一套完整的基于zookeeper的分布式配置统一解决方案。支持配置(配置项+配置文件)的分布式化管理,配置发布统一化,极简的使用方式(注解式编程 或 XML代码无代码侵入模式),低侵入性或无侵入性、强兼容性,需要Spring编程环境。其依赖于:Mysql、Tomcat、Nginx、zookeeeper、Redis。 更多详细介绍请移步 https://github.com/knightliao/disconf

来自王安琪


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表