zookeeper + kazoo 用python實現(xiàn)一個簡單的發(fā)布訂閱功能

zookeeper主要的功能是數(shù)據(jù)的存儲與分配,zookeeper的API可以根據(jù)開發(fā)者的需求設(shè)計不同的工作模式工扎,因此可以適用于很多場景之中。
這里用python寫了一個例子來實現(xiàn)簡單的發(fā)布訂閱功能。例子中實現(xiàn)了發(fā)布偿凭、監(jiān)視的功能齐蔽,完整的發(fā)布訂閱還有很多功能需要實現(xiàn)两疚,都可以通過zookeeper協(xié)助實現(xiàn),例子中實現(xiàn)了server發(fā)布和client接收的功能含滴。

  • 首先我們需要搭建一個zookeeper集群诱渤,這里就不詳講了,可以參考http://www.reibang.com/p/b76628b82208谈况。例子中用了3臺虛擬機每臺分別搭建一個zookeeper服務(wù)來實現(xiàn)zookeeper集群勺美。
  • 安裝kazoo
pip3 install kazoo
  • 發(fā)布端代碼
#!/bin/usr/python
#_*_ coding: utf-8 _*_

import sys
from myzk import ZooKeeper

zk = ZooKeeper(hosts='192.168.137.129:2181,192.168.137.130:2181,192.168.137.131:2181')
path = "/monitor/" + sys.argv[1]
data = sys.argv[2]
zk.create_nodes(path, data)
  • 接收端代碼
#!/bin/usr/python
#_*_ coding: utf-8 _*_

import sys
from myzk import ZooKeeper

zk = ZooKeeper(hosts='192.168.137.129:2181,192.168.137.130:2181,192.168.137.131:2181')
zk.watch_child_node("/monitor")
  • zookeeper類
#!/bin/usr/python
#_*_ coding: utf-8 _*_

import time
from kazoo.client import KazooClient,ChildrenWatch,DataWatch

class ZooKeeper(KazooClient):
    def __init__(self, timeout=15, *args, **kwargs):
        super().__init__(timeout=timeout, *args, **kwargs)
        self.start()

    def __del__(self):
        self.stop()

    def create_path(self, zk_path):
        self.ensure_path(zk_path)
        return

    def update_nodes_data(self, zk_path, data):
        self.set(zk_path, bytes(data, encoding="utf8"))
        return

    def create_nodes(self, zk_path, data):
        self.create(zk_path, bytes(data, encoding="utf8"))
        return

    def get_data(self, zk_path):
        if self.exists(zk_path):
            return self.get(zk_path)
        else:
            print("node not exists")
            return

    def watch_child_node(self, zk_path):
        @ChildrenWatch(client=self, path=zk_path, send_event=True)
        def get_changes(children, event):
            print(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) + " node childs had been change")
            print("now: ", children)
            if event:
                print(event)
            return children
        while True:
            time.sleep(5)
            print(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) + " watching...")

    def watch_node_data(self, zk_path):
        @DataWatch(client=self, path=zk_path)
        def watch_node(data, stat):
            print(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) + " data changed")
            if data:
                print("Version: %s, data: %s" % (stat.version, data.decode("utf8")))
        while True:
            time.sleep(5)
            print(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) + " watching...")

    

把接收端和Zookeeper類的代碼放在三臺server上,然后均運行接收端代碼碑韵,然后隨便選一臺server運行發(fā)布端代碼赡茸,每創(chuàng)建一個新節(jié)點,三個接收端都會發(fā)現(xiàn)祝闻。
運行結(jié)果:
我們隨機找一臺服務(wù)器運行發(fā)布端代碼


server.png

接收端1


client1.png

接收端2


client2.png

接收端3


client3.png

可以看出每次新增一個znode占卧,接收端都能響應(yīng)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末联喘,一起剝皮案震驚了整個濱河市华蜒,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌豁遭,老刑警劉巖友多,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異堤框,居然都是意外死亡域滥,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進店門蜈抓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來启绰,“玉大人,你說我怎么就攤上這事沟使∥桑” “怎么了?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長着倾。 經(jīng)常有香客問我拾酝,道長,這世上最難降的妖魔是什么卡者? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任蒿囤,我火速辦了婚禮,結(jié)果婚禮上崇决,老公的妹妹穿的比我還像新娘材诽。我一直安慰自己,他們只是感情好恒傻,可當(dāng)我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布脸侥。 她就那樣靜靜地躺著,像睡著了一般盈厘。 火紅的嫁衣襯著肌膚如雪睁枕。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天沸手,我揣著相機與錄音外遇,去河邊找鬼。 笑死罐氨,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的滩援。 我是一名探鬼主播栅隐,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼玩徊!你這毒婦竟也來了租悄?” 一聲冷哼從身側(cè)響起恩袱,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤泣棋,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后畔塔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體潭辈,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年澈吨,在試婚紗的時候發(fā)現(xiàn)自己被綠了把敢。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡谅辣,死狀恐怖修赞,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情桑阶,我是刑警寧澤柏副,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布勾邦,位于F島的核電站,受9級特大地震影響割择,放射性物質(zhì)發(fā)生泄漏眷篇。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一锨推、第九天 我趴在偏房一處隱蔽的房頂上張望铅歼。 院中可真熱鬧,春花似錦换可、人聲如沸椎椰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽慨飘。三九已至,卻和暖如春译荞,著一層夾襖步出監(jiān)牢的瞬間瓤的,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工吞歼, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留圈膏,地道東北人。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓篙骡,卻偏偏與公主長得像稽坤,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子糯俗,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,658評論 2 350