成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

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

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

瀏覽:2日期: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 編程
相關文章:
主站蜘蛛池模板: 台湾三级在线播放 | 在线成人亚洲 | 999久久久精品视频在线观看 | 国产精品系列在线一区 | 欧美人一级淫片a免费播放 欧美人与z0z0xxxx | 真实一级一级一片免费视频 | 久久一本 | 最新欧美精品一区二区三区 | 色午夜在线 | 视频一区二区在线 | 精品国产欧美一区二区五十路 | 天堂va欧美ⅴa亚洲va一国产 | 成人欧美一区二区三区视频 | 一区二区三区视频网站 | 亚洲精品手机在线 | 1024香蕉视频在线播放 | 国产精品黑丝 | 欧美成人看片黄a免费 | 久久国产情侣 | 国产一级淫片a免费播放口之 | 免费国产a国产片高清不卡 免费国产不卡午夜福在线 免费国产不卡午夜福在线观看 | 精品韩国主播福利视频在线观看一 | 成人午夜免费在线观看 | 精品国产欧美一区二区五十路 | 三级黄色网址 | 久草a在线| avove在线播放 | 国产第三区 | 性欧美videofree中文字幕 | 免费的三级网站 | 欧美日韩视频在线第一区二区三区 | 99爱在线精品视频网站 | 狠狠色噜狠狠狠狠色综合久 | 未成人做爰视频www 窝窝午夜精品一区二区 | 欧美一级高清免费播放 | 国产成人精品福利网站在线 | 成人深夜福利在线播放不卡 | 亚洲人成亚洲精品 | 91国在线啪精品一区 | 日本特黄特色高清免费视频 | 曰本女同互慰高清在线观看 |