集群动态配置
Zookeeper 3.5.0 以前,Zookeeper集群角色要发生改变的话,只能通过停掉所有的Zookeeper服务,修改集群配置,重启服务来完成,这样集群服务将有一段不可用的状态,为了应对高可用需求,Zookeeper 3.5.0 提供了
支持动态扩容/缩容的 新特性。但是通过客户端API可以变更服务端集群状态是件很危险的事情,所以在zookeeper 3.5.3 版本要用动态配置,需要开启超级管理员身份验证模式 ACLs。如果是在一个安全的环境也可以通过配置
系统参数 -Dzookeeper.skipACL=yes 来避免配置维护acl 权限配置
第一步:
按照上节课的方式,先配置一个超级管理员(如果不配管理员,也可以设置系统参数 -Dzookeeper.skipACL=yes):
在zookeeper启动脚本中添加 超级管理员授权模式: echo -n gj:123 | openssl dgst -binary -sha1 | openssl base64 // RRCKWv2U2e99M6UmsFaJiQ2xStw= -Dzookeeper.DigestAuthenticationProvider.superDigest=gj:RRCKWv2U2e99M6UmsFaJiQ2xStw=

配置动态文件
修改配置 zoo1.cfg
注意这里去除了端口号,添加了
reconfigEnabled : 设置为true 开启动态配置
dynamicConfigFile : 指定动态配置文件的路径

创建文件 zoo_replicated1.cfg.dynamic
动态配置文件,加入集群信息 server.A=B.C.D.E;F A: 服务的唯一标识 B: 服务对应的IP地址, C: 集群通信端口 D: 集群选举端口 E: 角色, 默认是 participant,即参与过半机制的角色,选举,事务请求过半提交,还有一个是observer, 观察者,不参与选举以及过半机制。 之后是一个分号,一定是分号, F:服务IP:端口
server.1=192.168.109.200:2001:3001:participant;192.168.109.200:2181 server.2=192.168.109.200:2002:3002:participant;192.168.109.200:2182 server.3=192.168.109.200:2003:3003:participant;192.168.109.200:2183
依次配置其他服务 zoo2.cfg ,zoo3.cfg注意数据文件的路径
依次启动所有服务 如: ./bin/zkServer.sh start conf/zoo1.cfg 查看集群状态: ./bin/zkServer.sh status conf/zoo1.cfg
连上任意一台服务器:
查看集群配置 config // 将会把动态配置打印出来 也可以直接查看目录 /zookeeper/config 该节点存储了集群信息 如果要修改集群状态,需要授权登录 addauth digest gj:123 reconfig -remove 3 // 移除serverId为 3 的机器 // 把对应的机器加进来 reconfig -add server.3=192.168.109.200:2003:3003:participant;192.168.109.200:2183
如果要变更/或者添加新的服务需要将服务加到配置文件 zoo_replicated1.cfg.dynamic 中,启动服务
然后通过reconfig 命令进行添加或者变更服务角色,但是需要保证服务列表中 participant 角色能够形成集群(过半机制)
客户端可以通过监听 /zookeeper/confg 节点,来感知集群的变化。从而实现集群的动态变更.
Zookeeper 类提供了对应的API 用来更新服务列表 : updateServerList
(完整的工程代码,在课程对应的资料包中)
Watcher watcher = new Watcher() { @Override public void process(WatchedEvent event) { if (event.getType() == Event.EventType.None && event.getState() == Event.KeeperState.SyncConnected){ countDownLatch.countDown(); log.info(" 连接建立"); // start to watch config try { log.info(" 开始监听:{}",ZooDefs.CONFIG_NODE); zookeeper.getConfig(true,null); } catch (KeeperException e) { e.printStackTrace(); } catch (InterruptedException e) { e.printStackTrace(); } }else if( event.getPath()!=null && event.getPath().equals(ZooDefs.CONFIG_NODE)){ try { byte[] config = zookeeper.getConfig(this, null); String clientConfigStr = ConfigUtils.getClientConfigStr(new String(config)); log.info(" 配置发生变更: {}",clientConfigStr); zookeeper.updateServerList(clientConfigStr.split(" ")[1]); } catch (KeeperException e) { e.printStackTrace(); } catch (InterruptedException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } } };
Curator 也自带了动态配置的监听,不需要额外的配置和代码实现监听更新;

浙公网安备 33010602011771号