使用场景
整个系统中分master和server两种角色,每个master、server都需要知道集群内当前可用的server列表。
原处理方式:master负责集群server信息的收集和分发。server启动后和master建立长连接并心跳检测,master收集server的新增和disconnect,并将收集到的信息分发给所有server。
原存在问题:master和server耦合较重;master比较难扩展。
使用方式
每个server对应一个Zookeeper的一个子节点,所有master和push通过获取所有子节点取得server列表,当server disconnect时Zookeeper通知所有机器重新获取Server列表。
代码示例
创建zookeeper节点的代码
package com.lp.zookeeper;
import java.io.IOException;
import org.apache.zookeeper.CreateMode;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.ZooDefs.Ids;
import org.apache.zookeeper.ZooKeeper;
public class ZookeeperCreateNode {
private static ZooKeeper zk;
public static void main(String[] args) {
try {
//创建zookeeper链接实例
zk = new ZooKe