智慧的老鸟

一个程序员需要有一棵Gank的心,Dota能培养我。

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

利用zookeeper c api进行zk实例的初始化和权限添加时,喷到了一个情况:如代码所示

zk = zookeeper_init(url.c_str(), watcher, 30000, 0, 0, 0);
    if(zk != NULL)
    {  
        AC_INFO("zk connect sucess, hostip=%s", url.c_str());
    }  
    else
    {  
        AC_ERROR("zk connect error, hostip=%s", url.c_str());
        return false;
    }    

<<<<<<

    int rc = zoo_add_auth(zk, "digest", userauth.c_str(), userauth.length(), NULL, NULL);
    if(rc == ZOK)
        AC_INFO("zk addauth sucess, userauth=%s", userauth.c_str());
    else
    {  
        AC_ERROR("zk addauth error, userauth=%s", userauth.c_str());
        return false;
    }  

结果zoo_add_auth失败,rc = -9;查看源码得知,这是zoo_add_auth函数的参数失效所致,即zoo_state(zk) = 0;为什么呢?

原来,zookeeper_init是一个异步函数,未等zk初始化成功,就执行了zoo_add_auth函数,而zoo_add_auth传入的zk必须是创建好的,否则就返回-9.

基于此,在<<<<<<出添加如下代码,即可解决

    while(zoo_state(zk) == 0)
    {  
    } 

 

posted on 2013-03-18 18:56  智慧的老鸟  阅读(1424)  评论(0编辑  收藏  举报