基于python操纵zookeeper介绍

by:授客  QQ:1033553122

测试环境

Win7 64位

Python 3.3.4

kazoo-2.6.1-py2.py3-none-any.whl(windows)

kazoo-2.6.1.tar.gz (linux)

https://pypi.org/project/kazoo/#files

zookeeper-3.4.13.tar.gz

下载地址:

http://zookeeper.apache.org/releases.html#download

https://www.apache.org/dyn/closer.cgi/zookeeper/

https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/

代码实践

kazooStudy.py

#!/usr/bin/env python 3.4.0

#-*- encoding:utf-8 -*-

 

__author__ = 'shouke'

 

 

import threading

import time

from kazoo.client import  KazooClient

from kazoo.client import KazooState

from kazoo.retry import KazooRetry

def restart_zk_client():

'''重启zookeeper会话'''

    global zk_client

global zk_conn_stat

try:

zk_client.restart()

except Exception as e:

print('重启zookeeper客户端异常:%s' % e)

zk_conn_stat = 0 # zookeeper连接状态 1-LOST   2-SUSPENDED 3-CONNECTED/RECONNECTED

def zk_conn_listener(state):

'''zookeeper连接状态监听器'''

 

    global  zk_conn_stat

if state == KazooState.LOST:

print('zookeeper connection lost')

zk_conn_stat = 1

# Register somewhere that the session was lost

 

        thread = threading.Thread(target=restart_zk_client)

thread.start()

elif state == KazooState.SUSPENDED:

print('zookeeper connection dicconnected')

zk_conn_stat = 2

# Handle being disconnected from Zookeeper

    else:

zk_conn_stat = 3

print('zookeeper connection cconnected/reconnected')

# Handle being connected/reconnected to Zookeeper

 

# 监视器

# 当节点有变化、节点被删除时,将以多线程的方式调用以参数形式传递给get()、exists()的监视函数,监视函数将会接收到一个WatchedEvent实例

def event_listener(event):

print(event)

if __name__ == '__main__':

try:

# 建立连接

        zk_client = KazooClient(hosts='127.0.0.1:2181')

zk_client.add_listener(zk_conn_listener) # 添加监听器,监听连接状态

        zk_client.start() # 初始化到zk的连接,可以设置超时时间 zk_client.start(timeout=15) 默认15秒

 

        print('zk_client state:', zk_client.state) # 查看链接状态

 

        # 创建节点

        # ensure_path() 递归创建path中不存在的节点,但是不能为节点设置数据,仅ACL.

        zk_client.ensure_path('/node1')

# 创建永久节点

        # create创建节点的同时,可为节点设置数据,要求path路径必须存在

        if not zk_client.exists('/node1/subNode1'):

zk_client.create('/node1/subNode1', b'sub node1')

# 创建临时节点

        # 注意:会话丢失、重启会话会导致zookeeper删除重启会话前创建的临时节点

        if not zk_client.exists('/node1/subNode2'):

zk_client.create('/node1/subNode2', b'sub node2', ephemeral=True)

# 创建有序临时节点

        zk_client.create('/node1/subNode', b'sub nodexxxx', ephemeral=True, sequence=True)

# 读取数据

        # 判断节点是否存在

        if zk_client.exists('/node1'): # 如果返回值为None则表示不存在给定节点

            print('存在节点node1,节点路径/node1')

# 获取节点相关数据

            data, stat = zk_client.get('/node1')

if stat:

print("Version: %s, data: %s" % (stat.version, data.decode("utf-8")))

# 获取给定节点的子节点

            children = zk_client.get_children('/node1')

print('node1子节点 有 %s 子节点,节点名称为: %s' % (len(children), children))

print('/ 子节点', zk_client.get_children('/'))

# 更新节点

        # 更新节点数据

        zk_client.set("/node1/subNode2", b"some new data")

# 删除节点 recursive参数可选,递归删除节点数据

        zk_client.delete("/node1", recursive=True)

# 重试命令

        try:

result = zk_client.retry(zk_client.get, "/node1/subNode3")

print(result)

# 自定义重试

            # max_tries 出错最大重试次数, ignore_expire False-重试的时候忽略会话过期,否则不忽略

            kr = KazooRetry(max_tries=3, ignore_expire=False)

result = kr(zk_client.get, "/node1/subNode3")

except Exception as e:

print('/node1/subNode3 不存在,所以会运行出错')

# 释放客户端占用资源,移除连接

        zk_client.stop()

#  zk_client.stop() 会导致zk_client连接状态变成 LOST,进而触发线程调用函数 restart_zk_client,

        # 该函数未执行完成的情况下,如果马上执行类似get,create等函数,会导致运行出错

        #

 

        while zk_conn_stat != 3:

continue

        else:

i = 0

while i < 3000:

if i % 200 == 0:

time.sleep(2)

print('创建新节点')

zk_client.ensure_path('/node1')

zk_client.ensure_path('/node1/subNode2')

zk_client.create('/node1/subNode', b'sub nodexxxx', ephemeral=True, sequence=True)

zk_client.set('/node1/subNode2', b'new data')

i += 1

# 关闭客户端前必须先调用stop,否则会报错

        zk_client.stop()

# 关闭客户端

        zk_client.close()

except Exception as e:

print('运行出错:%s' % e)

monitor.py

#!/usr/bin/env python

#-*- encoding:utf-8 -*-

 

__author__ = 'shouke'

 

import time

from kazoo.client import  KazooClient

from kazoo.client import KazooState

zk = KazooClient(hosts='10.118.52.26:2181')

zk.start()

@zk.add_listener

def my_listener(state):

if state == KazooState.LOST:

print('LOST')

# Register somewhere that the session was lost

    elif state == KazooState.SUSPENDED:

print('SUSPENDED')

# Handle being disconnected from Zookeeper

    else:

pass

        print('CONNECTED')

# Handle being connected/reconnected to Zookeeper

 

# 监视器

# 当节点有变化、节点被删除时,将以多线程的方式调用以参数形式传递给get()、exists()的监视函数,监视函数将会接收到一个WatchedEvent实例

def event_listener(event):

print(event)

children = zk.get_children('/node1',watch=event_listener)

print('node1 has %s children with names %s' % (len(children), children))

# 更高级监视api

# 监视子节点的编号

@zk.ChildrenWatch('/node1')

def watch_children(children):

print("Children are now: %s" % children)

# 监视节点数据变更

@zk.DataWatch("/node1/subNode2") #

def watch_node(data, state):

"""监视节点数据是否变化"""

    if state:

print("Version:", state.version, "data:", data)

# 空转

i = 0

while i< 100:

# children = zk.get_children('/node1',watch=event_listener)

    # print('node1 has %s children with names %s' % (len(children), children))

    time.sleep(1)

zk.stop()

zk.close()

 

 

关于kazooClient连接状态说明

LOST

CONNECTED

SUSPENDED

KazooClient客户端实例刚创建时,处于LOST状态,同zookeeper建立连接后,转为CONNECTED 。如果连接出问题、切换到不同的zookeeper集群几点,转为SUSPENDED状态,当你知道暂时不能执行命令,如果zookeeper节点不再是集群的一部分,连接将丢失,也会导致 SUSPENDED状态

客户端再次同zookeeper建立连接,如果会话不存在,客户端连接状态将转为LOST,如果会话没有过期,可用则转为CONNECTED

 

运行效果

参考链接:

https://kazoo.readthedocs.io/en/latest/basic_usage.html

Python 基于python操纵zookeeper介绍的更多相关文章

  1. Python 基于Python实现的ssh兼sftp客户端(上)

    基于Python实现的ssh兼sftp客户端   by:授客 QQ:1033553122 实现功能 实现ssh客户端兼ftp客户端:实现远程连接,执行linux命令,上传下载文件 测试环境 Win7 ...

  2. Python 基于python操纵redis入门介绍

    基于python操纵redis入门介绍 by:授客  QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3.3.2 基于Python操作R ...

  3. Python 基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现

    基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现   by:授客 QQ:1033553122 测试环境 功能需求 实现思路 代码实践(关键技术点实现) 代码模块组织 ...

  4. Python 基于Python结合pykafka实现kafka生产及消费速率&主题分区偏移实时监控

    基于Python结合pykafka实现kafka生产及消费速率&主题分区偏移实时监控   By: 授客 QQ:1033553122   1.测试环境 python 3.4 zookeeper- ...

  5. Python 基于Python从mysql表读取千万数据实践

    基于Python 从mysql表读取千万数据实践   by:授客 QQ:1033553122 场景:   有以下两个表,两者都有一个表字段,名为waybill_no,我们需要从tl_waybill_b ...

  6. Python 基于Python实现的ssh兼sftp客户端(下)

    基于Python实现的ssh兼sftp客户端   by:授客 QQ:1033553122 otherTools.py #!/usr/bin/env/ python # -*- coding:utf-8 ...

  7. Python基于Python实现批量上传文件或目录到不同的Linux服务器

    基于Python实现批量上传文件或目录到不同的Linux服务器   by:授客 QQ:1033553122 实现功能 1 测试环境 1 使用方法 1 1. 编辑配置文件conf/rootpath_fo ...

  8. Python 基于python编写一些算法程序等

    基于python编写一些算法程序等 by:授客 QQ:1033553122 QQ群:7156436 没特意去研究,只是这对群友在QQ群里(7156436)提出的一些小程序实现.编程题,算法.问题等,本 ...

  9. Python 基于python+mysql浅谈redis缓存设计与数据库关联数据处理

    基于python+mysql浅谈redis缓存设计与数据库关联数据处理 by:授客  QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3 ...

随机推荐

  1. .net MVC +EF+VUE做回合制游戏(一)

    刚毕业的新人,工作的时候试过用.net 框架,但是我发现写的前端代码都非常多,要写很多很多的原生,然后最近在看vue.js觉得还不错,可以减少前端很多dom操作. 至于做的东西我是想做一个游戏,一个回 ...

  2. Dotspatial 要素重叠部分去除

    private void toolStripButton32_Click(object sender, EventArgs e) { /重叠部分去除操作——测试成功 if (mapMain.Layer ...

  3. Odoo:全球第一免费开源ERP权威性能测试报告完整版(绝对珍藏)

    Odoo平台简介 Odoo(以前叫OpenERP)是世界排名第一的开源ERP系统,最早由比利时一家公司开发,经过十几年发展,目前全世界Odoo的使用者超过2百万人,Odoo被翻译成几十种语言,Odoo ...

  4. ArcGIS API For Javascript_4.8-渲染器Renderer

    渲染器:Renderer 类:esri / renderers / Renderer 继承: Renderer->Accessor 子类: ClassBreaksRenderer , Heatm ...

  5. 云计算CRM软件厂商,你青睐哪家?

    2018年CRM系统软件市场风起云涌,国内外厂商群雄逐鹿.2019年,新一轮的角逐已然展开.据Gartner报告称,CRM客户关系管理系统在2017年全球的销售额首次超越数据库管理系统((Databa ...

  6. 基于python语言的tensorflow的‘端到端’的字符型验证码识别源码整理(github源码分享)

    基于python语言的tensorflow的‘端到端’的字符型验证码识别 1   Abstract 验证码(CAPTCHA)的诞生本身是为了自动区分 自然人 和 机器人 的一套公开方法, 但是近几年的 ...

  7. Linux下查看文件内容的命令和工具

    1.catcat命令主要用来查看文件内容,创建文件,合并文件,追加文件等. 1.1.查看文件 格式:cat 文件名称 说明:这条命令会把文件内容全部输出到显示屏上. cat -n 文件名称:查看文件内 ...

  8. 磁盘阵列raid类型及含义

    raid0: 多块盘同时进行读写: 优点是读写效率高,缺点是没有数据冗余: 最少需要两块盘. raid1: 将数据盘都做镜像: 优点是有数据冗余:缺点是读写效率低,磁盘利用率低: 最少需要两块盘. r ...

  9. Java实现单链表

    真正的动态数据结构(引用和指针) 优点:真正的动态,不需要处理固定容量的问题. 缺点:丧失随机访问的能力. 链表就像寻宝,我们拿到藏宝图开始出发寻宝,每找到一个地方后,里面藏着下一步应该去哪里寻找.一 ...

  10. 为什么要重写hashcode和equals方法?初级程序员在面试中很少能说清楚。

    我在面试 Java初级开发的时候,经常会问:你有没有重写过hashcode方法?不少候选人直接说没写过.我就想,或许真的没写过,于是就再通过一个问题确认:你在用HashMap的时候,键(Key)部分, ...