经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 大数据/云/AI » Zookeeper » 查看文章
zookeeper【1】配置管理
来源:cnblogs  作者:撸码识途  时间:2018/11/28 9:58:28  对本文有异议

为什么要用统一配置?

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

 

采用方案

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

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

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

 

实现代码:

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

 

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号