今天按照视频,通过zookeeper来实现服务器的连接与上线,然后因为没有定义main方法,所以想通过JUnit来测试一些连接zookeeper服务器的方法,然后就一直出现返回空指针的错误。
代码:
package cn.itcast.bigdata.zk;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import org.apache.zookeeper.CreateMode;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.ZooDefs.Ids;
import com.sun.org.apache.bcel.internal.generic.NEW;
import com.sun.org.apache.xml.internal.security.Init;
import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.client.ZooKeeperSaslClient;
import org.apache.zookeeper.data.Stat;
import org.junit.Before;
import org.junit.Test;
import javafx.scene.chart.PieChart.Data;
public class SimpleClientZk {
private static final String connectString = "shizhan01:2181,shizhan02:2181,shizhan03:2181";
private static final int sessionTimeout = 2000;
ZooKeeper ZkClient = null;
public void init() throws Exception {
ZkClient = new ZooKeeper(connectString, sessionTimeout, new Watcher() {
@Override
public void process(WatchedEvent event) {
// TODO Auto-generated method stub
//收到事件通知后的回调函数(我们自己的事件处理逻辑) getType():事件类型
System.out.println(event.getType() + "------------" + event.getPath());
try {
ZkClient.getChildren("/", true);
} catch (Exception e) {
}
}
});
}
//创建数据节点到zk中
@Test
public void nodeCreate() throws Exception, InterruptedException {
String nodeCreate = ZkClient.create("/eclips", "hello".getBytes(), Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
}
//获取子节点
@Test
public void getChildren() throws Exception {
List childrennode = ZkClient.getChildren("/", true);
for(String child : childrennode ) {
System.out.println(child);
}
Thread.sleep(Long.MAX_VALUE);
}
//判断节点是否存在
@Test
public void testExist() throws Exception {
Stat stat = ZkClient.exists("/eclips", false);
System.out.println(stat == null ? "not exists":"znode exists");
}
//获取节点数据
@Test
public void getData() throws Exception, InterruptedException {
byte[] data = ZkClient.getData("/eclips", false, null);
System.out.println(new String(data));
}
//删除节点
@Test
public void deleteNode() throws Exception, KeeperException {
ZkClient.delete("/eclips", -1);
}
//修改节点
@Test
public void setNodeData() throws Exception, InterruptedException {
ZkClient.setData("/app1", "setdata".getBytes(), -1);
byte[] data = ZkClient.getData("/app1", false, null);
System.out.println(new String(data));
}
}
通过百度查阅一些资料后,终于发现问题所在,因为我的代码中所使用的对象是在我自己写的一个初始化方法init()中对其进行初始化的,而用JUnit测试方法时,方法中的对象都是独立存在的,所以会一直出现返回空指针的错误。
解决方法:在你的初始化方法init()的开头加一个@Before,用来初始化测试单元中的外部需求,完美解决。
@Before
public void init() throws Exception {
ZkClient = new ZooKeeper(connectString, sessionTimeout, new Watcher() {
@Override
public void process(WatchedEvent event) {
// TODO Auto-generated method stub
//收到事件通知后的回调函数(我们自己的事件处理逻辑) getType():事件类型
System.out.println(event.getType() + "------------" + event.getPath());
try {
ZkClient.getChildren("/", true);
} catch (Exception e) {
}
}
});
}