为什么要用统一配置?

我们做项目时用到的配置比如数据库配置等...我们都是写死在项目里面,如果需要更改,那么也是的修改配置文件然后再投产上去,那么问题来了,如果做集群的呢,有100台机器,这时候做修改那就太不切实际了;那么就需要用到统一配置管理啦。

采用方案

1.公共配置抽取存放于zookeeper中并落地数据库

2.对公共配置修改后发布到zookeeper中并落地数据库

3.对应用开启配置实时监听,zookeeper配置文件一旦被修改,应用可实时监听到并获取

实现代码:

  1. import java.io.Serializable;
  2.  
  3. public class Config implements Serializable{
  4.  
  5. /**
  6. *
  7. */
  8. private static final long serialVersionUID = 1L;
  9. private String userNm;
  10. private String userPw;
  11.  
  12. public Config() {
  13. }
  14. public Config(String userNm, String userPw) {
  15. this.userNm = userNm;
  16. this.userPw = userPw;
  17. }
  18. public String getUserNm() {
  19. return userNm;
  20. }
  21. public void setUserNm(String userNm) {
  22. this.userNm = userNm;
  23. }
  24. public String getUserPw() {
  25. return userPw;
  26. }
  27. public void setUserPw(String userPw) {
  28. this.userPw = userPw;
  29. }
  30. @Override
  31. public String toString() {
  32. return "Config [userNm=" + userNm + ", userPw=" + userPw + "]";
  33. }
  34.  
  35. }
  1. import org.I0Itec.zkclient.ZkClient;
  2.  
  3. public class ZkConfigMag {
  4.  
  5. private Config config;
  6. /**
  7. * 从数据库加载配置
  8. */
  9. public Config downLoadConfigFromDB(){
  10. //getDB
  11. config = new Config("nm", "pw");
  12. return config;
  13. }
  14.  
  15. /**
  16. * 配置文件上传到数据库
  17. */
  18. public void upLoadConfigToDB(String nm, String pw){
  19. if(config==null)config = new Config();
  20. config.setUserNm(nm);
  21. config.setUserPw(pw);
  22. //updateDB
  23. }
  24.  
  25. /**
  26. * 配置文件同步到zookeeper
  27. */
  28. public void syncConfigToZk(){
  29. ZkClient zk = new ZkClient("localhost:2181");
  30. if(!zk.exists("/zkConfig")){
  31. zk.createPersistent("/zkConfig",true);
  32. }
  33. zk.writeData("/zkConfig", config);
  34. zk.close();
  35. }
  36. }
  1. public class ZkConfigTest {
  2.  
  3. public static void main(String[] args) {
  4. ZkConfigMag mag = new ZkConfigMag();
  5. Config config = mag.downLoadConfigFromDB();
  6. System.out.println("....加载数据库配置...."+config.toString());
  7. mag.syncConfigToZk();
  8. System.out.println("....同步配置文件到zookeeper....");
  9.  
  10. //歇会,这样看比较清晰
  11. try {
  12. Thread.sleep(10000);
  13. } catch (InterruptedException e) {
  14. // TODO Auto-generated catch block
  15. e.printStackTrace();
  16. }
  17.  
  18. mag.upLoadConfigToDB("ccccc", "ppppp");
  19. System.out.println("....修改配置文件...."+config.toString());
  20. mag.syncConfigToZk();
  21. System.out.println("....同步配置文件到zookeeper....");
  22.  
  23. }
  24.  
  25. }
  1. import org.I0Itec.zkclient.IZkDataListener;
  2. import org.I0Itec.zkclient.ZkClient;
  3.  
  4. public class ZkGetConfigClient {
  5.  
  6. private Config config;
  7.  
  8. public Config getConfig() {
  9. ZkClient zk = new ZkClient("localhost:2181");
  10. config = (Config)zk.readData("/zkConfig");
  11. System.out.println("加载到配置:"+config.toString());
  12.  
  13. //监听配置文件修改
  14. zk.subscribeDataChanges("/zkConfig", new IZkDataListener(){
  15. @Override
  16. public void handleDataChange(String arg0, Object arg1)
  17. throws Exception {
  18. config = (Config) arg1;
  19. System.out.println("监听到配置文件被修改:"+config.toString());
  20. }
  21.  
  22. @Override
  23. public void handleDataDeleted(String arg0) throws Exception {
  24. config = null;
  25. System.out.println("监听到配置文件被删除");
  26. }
  27.  
  28. });
  29. return config;
  30. }
  31. public static void main(String[] args) {
  32. ZkGetConfigClient client = new ZkGetConfigClient();
  33. client.getConfig();
  34. System.out.println(client.config.toString());
  35. for(int i = 0;i<100;i++){
  36. System.out.println(client.config.toString());
  37. try {
  38. Thread.sleep(1000);
  39. } catch (InterruptedException e) {
  40. // TODO Auto-generated catch block
  41. e.printStackTrace();
  42. }
  43. }
  44.  
  45. }
  46.  
  47. }

zookeeper【1】配置管理的更多相关文章

  1. Zookeeper的功能以及工作原理

    1.ZooKeeper是什么?ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,它是集群的管理者,监视着集群中各个节点的状态根据节点提交的 ...

  2. zookeeper web ui--&gt;node-zk-browser安装

    眼下公司正在使用zookeeper做配置管理和其它工作,在网上找几个zookeeper管理工具,都不尽人意,要么功能不够强大,要么不能友好的浏览zk树形结构.我的想法是zk管理工具,应该有一个树形结构 ...

  3. Zookeeper的功能以及工作原理 (转自:http://www.cnblogs.com/felixzh/p/5869212.html)

    1.ZooKeeper是什么?ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,它是集群的管理者,监视着集群中各个节点的状态根据节点提交的 ...

  4. Zookeeper原理、安装、基本使用和API

     ZooKeeper ZooKeeper是一种分布式协调服务, 解决应用程序的分布式带来的问题.   1 分布式应用 分布式应用可以在给定时间(同时)在网络中的多个系统上运行,通过协调它们以快速有效的 ...

  5. zookeeper 动态管理nginx配置

    假设我们有一个场景,所有服务器共享同一份配置文件,我们肯定不可能单独手动维护每台服务器,这时可以利用zookeeper的配置管理功能. 环境:python + nginx + zookeeper 目的 ...

  6. 【11】JMicro微服务-配置管理

    如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 往下看前,建议完成前面1到10小节 JMicro目前仅支持基于Zookeeper做配置管理,全部配置信息可以在ZK做增删改查 ...

  7. zookeeper原理及功能介绍(转)

    本文转自https://www.cnblogs.com/onetwo/p/6420062.html 1.ZooKeeper是什么? ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务, ...

  8. Zookeeper 应用程序

    Zookeeper为分布式环境提供灵活的协调基础架构.ZooKeeper框架支持许多当今最好的工业应用程序.我们将在本章中讨论ZooKeeper的一些最显着的应用. 雅虎 ZooKeeper框架最初是 ...

  9. Zookeeper概念学习系列之zookeeper是什么?

    1. Zookeeper是Hadoop的分布式协调服务. 2. 分布式应用程序可以基于它,来实现同步服务,配置维护和命名服务等. 3. zookeeper可以保证数据在zookeeper集群之间的数据 ...

  10. Zookeeper的功能以及工作原理(转)

    本文转自https://www.cnblogs.com/felixzh/p/5869212.html Zookeeper的功能以及工作原理   1.ZooKeeper是什么?ZooKeeper是一个分 ...

随机推荐

  1. CodeForces 1096E: The Top Scorer

    一道经典组合数学+容斥题. 题目传送门:CF1096E. 题意简述: \(p\) 个人,每个人有得分 \(a_i\). 总得分 \(\sum a_i = s\). 第一个人得分 \(a_1 \ge r ...

  2. reshape中的-1

    >>> a = np.array([[1,2,3], [4,5,6]]) >>> np.reshape(a, (3,-1)) # the unspecified v ...

  3. sql 内联,左联,右联,全联

    联合查询效率较高,以下例子来说明联合查询(内联.左联.右联.全联)的好处: T1表结构(用户名,密码) userid (int) username varchar(20) password  varc ...

  4. Sublime Text 3 注册码失效(被移除)解决方法

    最近Sublime Text 3 增加了注册码验证功能,如果你使用共享版本的注册码,可能会提示注册码失效,但是却可以正常激活. 只需要把下面的字段加入到你的hosts文件即可: 127.0.0.1 l ...

  5. Mysql5.6版本内存占用过高解决方法[链接]

    传送门: http://blog.linsongzheng.com/archives/159.html

  6. tensorflow中的boolean_mask

    将mask中所有为true的抽取出来,放到一起,这里从n维降到1维度 tensor = [[1, 2], [3, 4], [5, 6]] import numpy as np mask=np.arra ...

  7. 你竟然在公钥中下毒!——如何在RSA公钥中添加后门

    原文:http://www.hackdig.com/?01/hack-17893.htm 分享到: 当我知道它是如何运行时,我惊得下巴都掉了.这是一个非常简单的手法,但这篇文章会颠覆你之前对RSA的看 ...

  8. 读书笔记--C陷阱与缺陷(三)

    第三章 1. 指针与数组 书中强调C中数组注意的两点: 1)     C语言只有一维数组,但是数组元素可以是任何类型对象,是另外一个数组时就产生了二维数组.数组大小是常数(但GCC实现了变长数组..) ...

  9. [android] The_connection_to_adb_is_down__and_a_severe_error_has_occured解决方案

    初学安卓,这是我碰到的第一个问题,从网上找了些解决方法,同时也把问题解决了. 方案一 1.先把eclipse关闭. 2.在管理器转到你的android SDK 的platform-tools下, 如图 ...

  10. HBase(五)HBase的API操作

    一.项目环境搭建 新建 Maven Project,新建项目后在 pom.xml 中添加依赖: <dependency> <groupId>org.apache.hbase&l ...