在先前的章节中,我们利用zkCli去了解了一下基本的zookeeper的操作,在接下来的章节中,我们将会学习一下在应用中是如何利用zookeeper的api的,接下来我们将利用一个程序展示一下,如何来创建一个回话和监视。那么下面我们将开始一个主从模式的结构例子。
创建一个zookeeper的会话
如下面所示,每一个建立的会话一旦它的连接被破坏,将会转移到其他的zookeeper服务,只要会话保持通畅,那么句柄将会有效。那么zookeeper客户端类库将会经历的保持连接。如果句柄关闭了,那么zookeeper客户端的类库会告诉zookeeper服务端终止会话。如果zookeeper了解到客户端已经死掉了,它将会验证会话。如果以后客户端向再次恢复这个会话,将会通过这个句柄来验证一个会话的有效性。
Zookeeper的构造函数如下所示
ZooKeeper(
String connectString,
int sessionTimeout,
Watcher watcher)
connectString:包含了zookeeper服务端的主机名和端口号,
sessionTimeOut:会话的超时时间,是以毫秒为单位的
watcher:当我们收到一个会话事件的时候,需要去创建一个对象。因为watch是一个接口,因此我们需要去实现该接口,从而完成zookeeper构造函数的初始化。客户端需要用监视去观察zookeeper的会话状态。当客户端建立连接或者失去连接的时候,就会创建该事件,该事件也能够利用来监视zookeeper数据的改变。最后如果会话过期后,该事件也可以监听到,最终通过客户端。
实现一个监视
为了能够通知客户端,我们需要实现一个监视。该接口信息如下所示
public interface Watcher {
void process(WatchedEventevent);
}
实现一个watcher
/**
* @FileName: master.java
* @Package:com.test
* @Description: TODO
* @author: LUCKY
* @date:2016年1月15日 下午7:54:58
* @version V1.0
*/
package com.test;
import java.io.IOException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooKeeper;
/**
* @ClassName: master
* @Description: 实现一个maste的watcher
* @author: LUCKY
* @date:2016年1月15日 下午7:54:58
*/
public class master implements Watcher {
ZooKeeper zk;
String hostPort;
/**
*
*/
public master(String hostPort) {
this.hostPort = hostPort;
}
void startZk() throws IOException {
zk = new ZooKeeper(hostPort, 15000, this);
}
public void process(WatchedEvent event) {
System.out.println(event);
}
void stopZk() throws Exception {
zk.close();
}
public static void main(String[] args) throws Exception {
master m = new master("100.66.162.90:2180");
m.startZk();
Thread.sleep(60000);
m.stopZk();
}
}
上面的例子就是一个简单的实现water的master类,可以尝试连接一下,看一下控制台打印的信息