zookeeper错误KeeperErrorCode = ConnectionLoss解决
来源:互联网 发布:linux 驱动开发 编辑:程序博客网 时间:2024/06/06 01:51
原因:
一般是由于连接还未完成就执行zookeeper的get/create/exsit操作引起的.
解决方法:
利用"CountDownLatch 类 + zookeeper的watcher + zookeeper的getStat" 实现连接完成后再调用.
可防止此错误发生.
示例类如下(为一配置获取类):
- import java.util.concurrent.CountDownLatch;
- import org.apache.zookeeper.WatchedEvent;
- import org.apache.zookeeper.Watcher;
- import org.apache.zookeeper.Watcher.Event.KeeperState;
- import org.apache.zookeeper.ZooKeeper;
- import org.apache.zookeeper.ZooKeeper.States;
- import org.apache.zookeeper.data.Stat;
- public class Conf{
- public static void waitUntilConnected(ZooKeeper zooKeeper, CountDownLatch connectedLatch) {
- if (States.CONNECTING == zooKeeper.getState()) {
- try {
- connectedLatch.await();
- } catch (InterruptedException e) {
- throw new IllegalStateException(e);
- }
- }
- }
- static class ConnectedWatcher implements Watcher {
- private CountDownLatch connectedLatch;
- ConnectedWatcher(CountDownLatch connectedLatch) {
- this.connectedLatch = connectedLatch;
- }
- @Override
- public void process(WatchedEvent event) {
- if (event.getState() == KeeperState.SyncConnected) {
- connectedLatch.countDown();
- }
- }
- }
- static public Conf Instance(){
- if(static_ == null){
- static_ = new Conf();
- }
- return static_;
- }
- public boolean Init(String hostports, int times){
- try{
- CountDownLatch connectedLatch = new CountDownLatch(1);
- Watcher watcher = new ConnectedWatcher(connectedLatch);
- zk_ = new ZooKeeper(hostports, times, watcher);
- waitUntilConnected(zk_, connectedLatch);
- }
- catch(Exception e){
- System.out.println(e);
- return false;
- }
- return true;
- }
- public String Get(String keys){
- String re = "";
- String ppath = "/zookeeper";
- int oldpos = -1;
- int pos = 0;
- while(true){
- pos = keys.indexOf(".", oldpos + 1);
- if(pos < 0){
- ppath += "/";
- String str = keys.substring(oldpos + 1);
- ppath += str;
- break;
- }
- ppath += "/";
- String str = keys.substring(oldpos + 1, pos);
- ppath += str;
- oldpos = pos;
- }
- Stat stat = new Stat();
- try{
- byte[] b = zk_.getData(ppath, false, stat); //获取节点的信息及存储的数据
- re = new String(b);
- }
- catch(Exception e){
- System.out.println(e);
- }
- return re;
- }
- private Conf(){
- }
- private ZooKeeper zk_;
- static private Conf static_;
- public static void main(String args[]){
- String hostports = "192.168.1.88:2181,192.168.1.88:2182,192.168.1.88:2183";
- Conf.Instance().Init(hostports, 1000);
- String str = Conf.Instance().Get("conf.logicpoint.subscriberserverip");
- str = Conf.Instance().Get("conf.logicpoint.subscriberserverport");
- System.out.println(str);
- while(true){
- try{Thread.sleep(100);}
- catch(Exception e){
- }
- }
- }
- }
- zookeeper错误KeeperErrorCode = ConnectionLoss解决
- zookeeper错误KeeperErrorCode = ConnectionLoss解决
- 关于zookeeper错误KeeperErrorCode = ConnectionLoss的问题
- org.apache.zookeeper.KeeperException$ConnectionLossException: KeeperErrorCode = ConnectionLoss for /
- ZooKeeper连接KeeperErrorCode = ConnectionLoss for /eclipse问题,暂无解决办法
- ConnectionLossException: KeeperErrorCode = ConnectionLoss 的解决办法
- 如何解决java接口访问ZooKeeper时的connectionloss错误
- zookeeper错误:KeeperErrorCode = NoChildrenForEphemerals的原因
- HBase报错:KeeperErrorCode = ConnectionLoss for /hbase
- Zookeeper报KeeperErrorCode = MarshallingError 错误的说明
- How-to resolve hbase shutdown caused by "KeeperErrorCode = ConnectionLoss for /hbase"
- eclipse连接hbase异常KeeperErrorCode = ConnectionLoss for /hbase/meta-region-server
- resourcemanager UI界面无法访问报错KeeperErrorCode = ConnectionLoss for /rmstore
- 【curator】KeeperErrorCode = Unimplemented for /zookeeper/crud
- KeeperErrorCode = Unimplemented for /service 错误
- java.io.IOException: org.apache.zookeeper.KeeperException$ConnectionLossException: KeeperErrorCode =
- zookeeper 启动报错 : KeeperErrorCode = NoNode for /XXX
- zookeeper 启动报错 : KeeperErrorCode = NoNode for /XXX
- eclipse升级后Android使用JAR报错
- C#入门经典—第七章
- Server Tomcat v7.0 Server at localhost was unable to start within 45 seconds
- 远程调用服务的设计构思(zookeeper的一种应用实践)
- 安卓客户端与服务器进行连接
- zookeeper错误KeeperErrorCode = ConnectionLoss解决
- 2013华为校园招聘上机题——约瑟夫环
- Unity 3D 动态创建对象,并渲染贴图,动态添加删除脚本
- sql2005/2008 删除过期备份
- 白话经典算法系列之七 堆与堆排序
- 通过Gearman实现MySQL到Redis的数据同步(异步复制)
- $.getJson()在IE中无法使用解决方案
- Android开发 ——线性布局文件、TextView、ListView的基本写法
- ubuntu安装svn全过程