日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Python通過zookeeper實現分布式服務代碼解析

瀏覽:60日期:2022-07-16 15:26:53

借助zookeeper可以實現服務器的注冊與發現,有需求的時候調用zookeeper來發現可用的服務器,將任務均勻分配到各個服務器上去.

這樣可以方便的隨任務的繁重程度對服務器進行彈性擴容,客戶端和服務端是非耦合的,也可以隨時增加客戶端.

zk_server.py

import threadingimport jsonimport socketimport sysfrom kazoo.client import KazooClient# TCP服務端綁定端口開啟監聽,同時將自己注冊到zkclass ZKServer(object): def __init__(self, host, port): self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) self.sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) self.host = host self.port = port self.sock.bind((host, port)) self.zk = None def serve(self): ''' 開始服務,每次獲取得到一個信息,都新建一個線程處理 ''' self.sock.listen(128) self.register_zk() print('開始監聽') while True: conn, addr = self.sock.accept() print('建立鏈接%s' % str(addr)) t = threading.Thread(target=self.handle, args=(conn, addr)) t.start() # 具體的處理邏輯,只要接收到數據就立即投入工作,下次沒有數據本次鏈接結束 def handle(self, conn, addr): while True: data=conn.recv(1024) if not data or data.decode(’utf-8’) == ’exit’:break print(data.decode(’utf-8’)) conn.close() print(’My work is done!!!’) # 將自己注冊到zk,臨時節點,所以連接不能中斷 def register_zk(self): ''' 注冊到zookeeper ''' self.zk = KazooClient(hosts=’127.0.0.1:2181’) self.zk.start() self.zk.ensure_path(’/rpc’) # 創建根節點 value = json.dumps({’host’: self.host, ’port’: self.port}) # 創建服務子節點 self.zk.create(’/rpc/server’, value.encode(), ephemeral=True, sequence=True)if __name__ == ’__main__’: if len(sys.argv) < 3: print('usage:python server.py [host] [port]') exit(1) host = sys.argv[1] port = sys.argv[2] server = ZKServer(host, int(port)) server.serve()

zk_client.py

import randomimport sysimport timeimport jsonimport socketfrom kazoo.client import KazooClient# 客戶端連接zk,并從zk獲取可用的服務器列表class ZKClient(object): def __init__(self): self._zk = KazooClient(hosts=’127.0.0.1:2181’) self._zk.start() self._get_servers() def _get_servers(self, event=None): ''' 從zookeeper獲取服務器地址信息列表 ''' servers = self._zk.get_children(’/rpc’, watch=self._get_servers) # print(servers) self._servers = [] for server in servers: data = self._zk.get(’/rpc/’ + server)[0] if data:addr = json.loads(data.decode())self._servers.append(addr) def _get_server(self): ''' 隨機選出一個可用的服務器 ''' return random.choice(self._servers) def get_connection(self): ''' 提供一個可用的tcp連接 ''' sock = None while True: server = self._get_server() print(’server:%s’ % server) try:sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)sock.connect((server[’host’], server[’port’])) except ConnectionRefusedError:time.sleep(1)continue else:break return sockif __name__ == ’__main__’: # 模擬多個客戶端批量生成任務,推送給服務器執行 client = ZKClient() for i in range(40): sock = client.get_connection() sock.send(bytes(str(i), encoding=’utf8’)) sock.close() time.sleep(1)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
蜜桃av一区二区三区电影| 日韩精品亚洲专区在线观看| 中日韩男男gay无套| 亚洲一区观看| 美女日韩在线中文字幕| 亚洲91在线| 另类小说一区二区三区| 美女少妇全过程你懂的久久| 亚洲色诱最新| 日韩av一区二区在线影视| 亚洲性视频在线| 日韩精品成人在线观看| 国产一区 二区| a天堂资源在线| 亚洲区欧美区| 久久久久国产精品一区二区| 日韩在线观看| 喷白浆一区二区| 美女久久99| 亚洲va中文在线播放免费| 日韩深夜视频| 亚洲一区导航| 国产一区二区三区四区五区| 男人的天堂亚洲一区| 99久久99视频只有精品| 亚洲ww精品| 影院欧美亚洲| 黑森林国产精品av| 欧美中文高清| 日韩在线观看一区二区| 日韩精品永久网址| 日本欧美一区二区在线观看| 久久精品在线| 欧美日韩一区二区三区在线电影| 国产精品yjizz视频网| 欧美日韩国产综合网| 青青国产91久久久久久| 午夜国产精品视频| 久久久国产精品网站| 男人操女人的视频在线观看欧美| 久久久久.com| 欧美日韩水蜜桃| 久久久91麻豆精品国产一区| 97久久亚洲| 亚洲精品一区二区妖精| 日韩伦理一区| 老司机免费视频一区二区| 91精品麻豆| 伊人精品久久| 国户精品久久久久久久久久久不卡| 日韩中文字幕av电影| 婷婷激情一区| 国产毛片精品| 国产精品综合| 麻豆精品在线| 国产精品18| 精品国产一区二| 国产情侣久久| 精品视频自拍| 久久蜜桃精品| 91久久久精品国产| 色爱综合网欧美| 黑森林国产精品av| 久久国产中文字幕| 国产精品伦理久久久久久| 日韩一区欧美二区| 六月婷婷一区| 亚洲精品伊人| 日韩国产成人精品| 亚洲乱亚洲高清| 久久国产尿小便嘘嘘| 在线精品国产亚洲| 四虎国产精品免费久久| 国产精品巨作av| 韩国久久久久久| 97精品视频在线看| 日韩高清成人| 亚洲91在线| 荡女精品导航| 日韩一区电影| 国产一区日韩一区| 国产一区二区三区自拍| 99在线|亚洲一区二区| 久久精品72免费观看| 高清一区二区三区| 日韩欧美看国产| 亚洲男女av一区二区| 日本91福利区| 亚洲免费福利| 91在线成人| 日产精品一区二区| 久久精品国产www456c0m| 欧美特黄一区| 国产精品香蕉| 日韩精品麻豆| 日韩精品一二三区| 国产视频一区二| 群体交乱之放荡娇妻一区二区| 久久中文视频| 国产精品欧美日韩一区| 午夜精品免费| 国产精品综合色区在线观看| 久久婷婷久久| 欧美国产先锋| 亚洲综合日本| 伊人久久大香线蕉av不卡| 日本免费一区二区视频| 麻豆视频在线看| 蜜桃视频免费观看一区| 91欧美日韩| 日韩综合一区二区| 亚洲性色视频| 欧美交a欧美精品喷水| 美女久久一区| 99视频一区| 欧美在线观看视频一区| 婷婷综合六月| 国产中文欧美日韩在线| 91综合久久爱com| 婷婷五月色综合香五月| 91久久中文| 久久青草久久| 狠狠久久伊人中文字幕| 欧美精品福利| 午夜电影一区| 国模 一区 二区 三区| 日本精品在线中文字幕| 精品黄色一级片| 国产精品日韩精品中文字幕| 久久国产尿小便嘘嘘| 日本不卡高清视频| 日韩国产欧美三级| 日韩精选在线| 日韩精品1区2区3区| 一区二区三区午夜视频| 亚洲精品女人| 午夜亚洲福利| 国产美女视频一区二区| 综合亚洲视频| 日韩在线视频一区二区三区| 国产精品xxx| 国产精品久久久一区二区| 亚洲三级在线| 日韩中文字幕高清在线观看| 色爱综合av| 欧美日韩激情| 亚洲精品影视| 欧美日一区二区三区在线观看国产免| 日韩国产欧美在线播放| 91成人福利| 精品久久福利| 91亚洲国产高清| 欧美综合另类| 国产精品视频一区二区三区四蜜臂 | 国产激情久久| 精品亚洲a∨| 99国产精品免费视频观看| 久久夜夜操妹子| 日韩在线电影| 黑森林国产精品av| 婷婷六月综合| 成人av动漫在线观看| 日韩视频二区| 日本不卡在线视频| 高清久久一区| 丝袜美腿一区二区三区| 日韩中出av| 色天使综合视频| 欧美在线91| av不卡在线看| 久久精品国内一区二区三区| 欧美精品一区二区三区精品| 国产精品v一区二区三区| 久久理论电影| 国产亚洲字幕| 久久中文字幕二区| 日韩一区二区三区精品| 中文字幕人成乱码在线观看 | 在线手机中文字幕| 日本v片在线高清不卡在线观看| 国产精品精品| 欧美视频精品全部免费观看| 久久一级电影| 国产精品手机在线播放| 免费观看日韩电影| 久久视频精品| 国产精品1区| 日韩黄色在线观看| 国产精品毛片| 欧美成人基地| 国产一区二区三区不卡视频网站| 国产视频一区三区| 亚洲国产不卡| 国内精品美女在线观看| 久久婷婷国产| 欧美日韩亚洲一区三区| 国产亚洲精品精品国产亚洲综合| 99riav国产精品| 美女亚洲一区| 天使萌一区二区三区免费观看|