Kazoo与chroot连接

时间:2015-09-24 21:43:32

标签: python apache-zookeeper kazoo

我想知道kazoo库中是否有一种方法可以让zookeeper在连接字符串中创建chroot路径,如果该路径还没有存在?有任何人对此有经验吗?我已经阅读了文档,但我还没有真正找到解决这个问题的方法。

我现在正在做的是连接到zookeeper服务器,确保路径存在,断开连接,然后重新连接路径,但这看起来效率不高。

connection1 = '127.0.0.102:2181,127.0.0.213:2181,127.0.0.134:2181'
connection2 = '127.0.0.102:2181,127.0.0.213:2181,127.0.0.134:2181/pathtoroot'
zk = KazooClient(hosts=connection1, timeout=2.0)
zk.start()
zk.ensure_path(pathtoroot)
zk.stop()
zk = KazooClient(hosts=connection2, timeout=2.0)
zk.start()

谢谢!

1 个答案:

答案 0 :(得分:2)

我找到了一种方法,无需重新连接即可。您必须在没有chroot的情况下进行连接,然后在确保路径存在后手动设置它。

connection1 = '127.0.0.102:2181,127.0.0.213:2181,127.0.0.134:2181'
zk = KazooClient(hosts=connection1, timeout=2.0)
zk.start()
zk.ensure_path(pathtoroot)
zk.chroot = pathtoroot