1.zookeeper监听器原理
1.首先要有一个main()线程
2.在main线程中创建zk客户端,zk客户端会创建两个线程,分别是: lintener()(负责监听)和connect()(负责网络连接通信)
3.connect()线程将注册的监听事传给zookeeper
4.zookeeper监听器中的注册监听列表会把注册的监听事件添加进去。
5.zookeeper一旦监听到路径或者数据有所改变会向listener()线程发送消息。
6.listener()线程内部调用了process()方法。
监听器监听的事件:
1.zookeeper监听节点位置发生变化get path [watch]
2.zookeeper监听节点增减的变化。 ls path[watch]
2.zookeeper选举机制
(1)半数机制:只有集群中有半数以上机器正存活,集群可用,zookeeper中适合安装半数台服务器。
(2)zookeeper配置文件中没有指定master和slave,它工作时,有一个节点为leader,其他为follewer,leader需要通过内部