zookeeper【1】配置管理
为什么要用统一配置?
我们做项目时用到的配置比如数据库配置等...我们都是写死在项目里面,如果需要更改,那么也是的修改配置文件然后再投产上去,那么问题来了,如果做集群的呢,有100台机器,这时候做修改那就太不切实际了;那么就需要用到统一配置管理啦。
采用方案
1.公共配置抽取存放于zookeeper中并落地数据库
2.对公共配置修改后发布到zookeeper中并落地数据库
3.对应用开启配置实时监听,zookeeper配置文件一旦被修改,应用可实时监听到并获取
实现代码:
- import java.io.Serializable;
- public class Config implements Serializable{
- /**
- *
- */
- private static final long serialVersionUID = 1L;
- private String userNm;
- private String userPw;
- public Config() {
- }
- public Config(String userNm, String userPw) {
- this.userNm = userNm;
- this.userPw = userPw;
- }
- public String getUserNm() {
- return userNm;
- }
- public void setUserNm(String userNm) {
- this.userNm = userNm;
- }
- public String getUserPw() {
- return userPw;
- }
- public void setUserPw(String userPw) {
- this.userPw = userPw;
- }
- @Override
- public String toString() {
- return "Config [userNm=" + userNm + ", userPw=" + userPw + "]";
- }
- }
- import org.I0Itec.zkclient.ZkClient;
- public class ZkConfigMag {
- private Config config;
- /**
- * 从数据库加载配置
- */
- public Config downLoadConfigFromDB(){
- //getDB
- config = new Config("nm", "pw");
- return config;
- }
- /**
- * 配置文件上传到数据库
- */
- public void upLoadConfigToDB(String nm, String pw){
- if(config==null)config = new Config();
- config.setUserNm(nm);
- config.setUserPw(pw);
- //updateDB
- }
- /**
- * 配置文件同步到zookeeper
- */
- public void syncConfigToZk(){
- ZkClient zk = new ZkClient("localhost:2181");
- if(!zk.exists("/zkConfig")){
- zk.createPersistent("/zkConfig",true);
- }
- zk.writeData("/zkConfig", config);
- zk.close();
- }
- }
- public class ZkConfigTest {
- public static void main(String[] args) {
- ZkConfigMag mag = new ZkConfigMag();
- Config config = mag.downLoadConfigFromDB();
- System.out.println("....加载数据库配置...."+config.toString());
- mag.syncConfigToZk();
- System.out.println("....同步配置文件到zookeeper....");
- //歇会,这样看比较清晰
- try {
- Thread.sleep(10000);
- } catch (InterruptedException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- mag.upLoadConfigToDB("ccccc", "ppppp");
- System.out.println("....修改配置文件...."+config.toString());
- mag.syncConfigToZk();
- System.out.println("....同步配置文件到zookeeper....");
- }
- }
- import org.I0Itec.zkclient.IZkDataListener;
- import org.I0Itec.zkclient.ZkClient;
- public class ZkGetConfigClient {
- private Config config;
- public Config getConfig() {
- ZkClient zk = new ZkClient("localhost:2181");
- config = (Config)zk.readData("/zkConfig");
- System.out.println("加载到配置:"+config.toString());
- //监听配置文件修改
- zk.subscribeDataChanges("/zkConfig", new IZkDataListener(){
- @Override
- public void handleDataChange(String arg0, Object arg1)
- throws Exception {
- config = (Config) arg1;
- System.out.println("监听到配置文件被修改:"+config.toString());
- }
- @Override
- public void handleDataDeleted(String arg0) throws Exception {
- config = null;
- System.out.println("监听到配置文件被删除");
- }
- });
- return config;
- }
- public static void main(String[] args) {
- ZkGetConfigClient client = new ZkGetConfigClient();
- client.getConfig();
- System.out.println(client.config.toString());
- for(int i = 0;i<100;i++){
- System.out.println(client.config.toString());
- try {
- Thread.sleep(1000);
- } catch (InterruptedException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- }
- }
zookeeper【1】配置管理的更多相关文章
- Zookeeper的功能以及工作原理
1.ZooKeeper是什么?ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,它是集群的管理者,监视着集群中各个节点的状态根据节点提交的 ...
- zookeeper web ui-->node-zk-browser安装
眼下公司正在使用zookeeper做配置管理和其它工作,在网上找几个zookeeper管理工具,都不尽人意,要么功能不够强大,要么不能友好的浏览zk树形结构.我的想法是zk管理工具,应该有一个树形结构 ...
- Zookeeper的功能以及工作原理 (转自:http://www.cnblogs.com/felixzh/p/5869212.html)
1.ZooKeeper是什么?ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,它是集群的管理者,监视着集群中各个节点的状态根据节点提交的 ...
- Zookeeper原理、安装、基本使用和API
ZooKeeper ZooKeeper是一种分布式协调服务, 解决应用程序的分布式带来的问题. 1 分布式应用 分布式应用可以在给定时间(同时)在网络中的多个系统上运行,通过协调它们以快速有效的 ...
- zookeeper 动态管理nginx配置
假设我们有一个场景,所有服务器共享同一份配置文件,我们肯定不可能单独手动维护每台服务器,这时可以利用zookeeper的配置管理功能. 环境:python + nginx + zookeeper 目的 ...
- 【11】JMicro微服务-配置管理
如非授权,禁止用于商业用途,转载请注明出处作者:mynewworldyyl 往下看前,建议完成前面1到10小节 JMicro目前仅支持基于Zookeeper做配置管理,全部配置信息可以在ZK做增删改查 ...
- zookeeper原理及功能介绍(转)
本文转自https://www.cnblogs.com/onetwo/p/6420062.html 1.ZooKeeper是什么? ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务, ...
- Zookeeper 应用程序
Zookeeper为分布式环境提供灵活的协调基础架构.ZooKeeper框架支持许多当今最好的工业应用程序.我们将在本章中讨论ZooKeeper的一些最显着的应用. 雅虎 ZooKeeper框架最初是 ...
- Zookeeper概念学习系列之zookeeper是什么?
1. Zookeeper是Hadoop的分布式协调服务. 2. 分布式应用程序可以基于它,来实现同步服务,配置维护和命名服务等. 3. zookeeper可以保证数据在zookeeper集群之间的数据 ...
- Zookeeper的功能以及工作原理(转)
本文转自https://www.cnblogs.com/felixzh/p/5869212.html Zookeeper的功能以及工作原理 1.ZooKeeper是什么?ZooKeeper是一个分 ...
随机推荐
- CodeForces 1096E: The Top Scorer
一道经典组合数学+容斥题. 题目传送门:CF1096E. 题意简述: \(p\) 个人,每个人有得分 \(a_i\). 总得分 \(\sum a_i = s\). 第一个人得分 \(a_1 \ge r ...
- reshape中的-1
>>> a = np.array([[1,2,3], [4,5,6]]) >>> np.reshape(a, (3,-1)) # the unspecified v ...
- sql 内联,左联,右联,全联
联合查询效率较高,以下例子来说明联合查询(内联.左联.右联.全联)的好处: T1表结构(用户名,密码) userid (int) username varchar(20) password varc ...
- Sublime Text 3 注册码失效(被移除)解决方法
最近Sublime Text 3 增加了注册码验证功能,如果你使用共享版本的注册码,可能会提示注册码失效,但是却可以正常激活. 只需要把下面的字段加入到你的hosts文件即可: 127.0.0.1 l ...
- Mysql5.6版本内存占用过高解决方法[链接]
传送门: http://blog.linsongzheng.com/archives/159.html
- tensorflow中的boolean_mask
将mask中所有为true的抽取出来,放到一起,这里从n维降到1维度 tensor = [[1, 2], [3, 4], [5, 6]] import numpy as np mask=np.arra ...
- 你竟然在公钥中下毒!——如何在RSA公钥中添加后门
原文:http://www.hackdig.com/?01/hack-17893.htm 分享到: 当我知道它是如何运行时,我惊得下巴都掉了.这是一个非常简单的手法,但这篇文章会颠覆你之前对RSA的看 ...
- 读书笔记--C陷阱与缺陷(三)
第三章 1. 指针与数组 书中强调C中数组注意的两点: 1) C语言只有一维数组,但是数组元素可以是任何类型对象,是另外一个数组时就产生了二维数组.数组大小是常数(但GCC实现了变长数组..) ...
- [android] The_connection_to_adb_is_down__and_a_severe_error_has_occured解决方案
初学安卓,这是我碰到的第一个问题,从网上找了些解决方法,同时也把问题解决了. 方案一 1.先把eclipse关闭. 2.在管理器转到你的android SDK 的platform-tools下, 如图 ...
- HBase(五)HBase的API操作
一.项目环境搭建 新建 Maven Project,新建项目后在 pom.xml 中添加依赖: <dependency> <groupId>org.apache.hbase&l ...