您的位置:首页 > 其它

利用淘宝diamond框架动态配置文件

2016-03-16 12:45 411 查看
在一个分布式环境中,同类型的服务往往会部署很多实例。这些实例使用了一些配置,为了更好地维护这些配置就产生了配置管理服务

Diamond则是淘宝开源的一种分布式配置管理服务的实现。Diamond本质上是一个Java写的Web应用,其对外提供接口都是基于HTTP协议的,在阅读代码时可以从实现各个接口的controller入手。
http://code.taobao.org/p/diamond/src/
使用方法和部署见diamond

自己使用类

import java.io.IOException;

import java.io.StringReader;

import java.math.BigDecimal;

import java.util.Enumeration;

import java.util.HashMap;

import java.util.Map;

import java.util.Map.Entry;

import java.util.Properties;

import java.util.ResourceBundle;

import java.util.Set;

import java.util.concurrent.Executor;

import org.apache.log4j.Logger;

import com.taobao.diamond.manager.DiamondManager;

import com.taobao.diamond.manager.ManagerListener;

import com.taobao.diamond.manager.impl.DefaultDiamondManager;

prop_group= flaginfo

prop_data_id=sso_login

local_conf = 0

/**

* 配置

* 1.先加载本地配置文件

* 2.如果配置需要从远程读取,那么获取远程文件配置覆盖掉本地配置

*/

public class SystemMessage {

private final static Logger logger = Logger.getLogger(SystemMessage.class);

public static Properties properties = new Properties();

//本地配置文件

private static final String BUNDLE_NAME = "system";

static{

//开启本地读取模式

ResourceBundle bundle = ResourceBundle.getBundle(BUNDLE_NAME);

//properties = new Properties();

Enumeration<String> e = bundle.getKeys();

while(e.hasMoreElements()){

String key = e.nextElement();

properties.put(key, bundle.getString(key));

}

if(bundle==null || !"1".equals(bundle.getString("local_conf"))){

DiamondManager manager = new DefaultDiamondManager(bundle.getString("prop_group"),

bundle.getString("prop_data_id"),

new ManagerListener() {

public void receiveConfigInfo(String configInfo) {

properties.putAll(getPropertiesForString(configInfo));

}

public Executor getExecutor() {

return null;

}

});

properties.putAll(manager.getAvailablePropertiesConfigureInfomation(5000));

}else{

logger.info("----------------------------------------------");

logger.info("----开启本地读取模式,读取本地配置system--------");

logger.info("----------------------------------------------");

}

}

private static Properties getPropertiesForString(String configInfo){

Properties p = new Properties();

try {

p.load(new StringReader(configInfo));

if(logger.isDebugEnabled()){

Set<Entry<Object,Object>> set = properties.entrySet();

Map allMap = new HashMap();

for(Entry e:set){

logger.debug(e.getKey()+"==>"+e.getValue());

}

}

} catch (IOException e) {

e.printStackTrace();

}

return p;

}

public static Map getAllConfig(){

return properties;

}

public static String getString(String key) {

return properties.getProperty(key);

}

/**

* 获取配置,并将配置值转换为整数

*

* @param key

* @return

*/

public static Integer getInteger(String key) {

String value = getString(key);

try {

return Integer.valueOf(value);

} catch (Exception e) {

return null;

}

}

/**

* 获取配置,并将配置值转换为Long类型

*

* @param key

* @return

*/

public static Long getLong(String key) {

String value = getString(key);

try {

return Long.valueOf(value);

} catch (Exception e) {

return null;

}

}

/**

* 获取配置,并将配置值转换为Double类型

*

* @param key

* @return

*/

public static Double getDouble(String key) {

String value = getString(key);

try {

return Double.valueOf(value);

} catch (Exception e) {

return null;

}

}

/**

* 获取配置,并将配置值转换为Float类型

*

* @param key

* @return

*/

public static Float getFloat(String key) {

String value = getString(key);

try {

return Float.valueOf(value);

} catch (Exception e) {

return null;

}

}

/**

* 获取配置,并将配置值转换为bool类型

*

* @param key

* @return

*/

public static Boolean getBoolean(String key) {

String value = getString(key);

try {

return Boolean.valueOf(value);

} catch (Exception e) {

return null;

}

}

/**

* 获取配置,并将配置值转换为BigDecimal类型

*

* @param key

* @return

*/

public static BigDecimal getBigDecimal(String key) {

String value = getString(key);

try {

return new BigDecimal(value);

} catch (Exception e) {

return null;

}

}

public static void main(String[] args) {

System.out.println(getAllConfig());

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: