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

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

通過實例解析Python RPC實現原理及方法

瀏覽:166日期:2022-07-18 13:22:27

單線程同步

使用socket傳輸數據 使用json序列化消息體 struct將消息編碼為二進制字節串,進行網絡傳輸

消息協議

// 輸入{ in: 'ping', params: 'ireader 0'}// 輸出{ out: 'pong', result: 'ireader 0'}

客戶端 client.py

# coding: utf-8# client.pyimport jsonimport timeimport structimport socketdef rpc(sock, in_, params): response = json.dumps({'in': in_, 'params': params}) # 請求消息體 length_prefix = struct.pack('I', len(response)) # 請求長度前綴 sock.sendall(length_prefix) sock.sendall(response) length_prefix = sock.recv(4) # 響應長度前綴 length, = struct.unpack('I', length_prefix) body = sock.recv(length) # 響應消息體 response = json.loads(body) return response['out'], response['result'] # 返回響應類型和結果if __name__ == ’__main__’: s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s.connect(('localhost', 8080)) for i in range(10): # 連續發送10個rpc請求 out, result = rpc(s, 'ping', 'ireader %d' % i) print out, result time.sleep(1) # 休眠1s,便于觀察 s.close() # 關閉連接

通過實例解析Python RPC實現原理及方法

服務端 blocking_single.py

# coding: utf8# blocking_single.pyimport jsonimport structimport socketdef handle_conn(conn, addr, handlers): print addr, 'comes' while True: # 循環讀寫 length_prefix = conn.recv(4) # 請求長度前綴 if not length_prefix: # 連接關閉了 print addr, 'bye' conn.close() break # 退出循環,處理下一個連接 length, = struct.unpack('I', length_prefix) body = conn.recv(length) # 請求消息體 request = json.loads(body) in_ = request[’in’] params = request[’params’] print in_, params handler = handlers[in_] # 查找請求處理器 handler(conn, params) # 處理請求def loop(sock, handlers): while True: conn, addr = sock.accept() # 接收連接 handle_conn(conn, addr, handlers) # 處理連接def ping(conn, params): send_result(conn, 'pong', params)def send_result(conn, out, result): response = json.dumps({'out': out, 'result': result}) # 響應消息體 length_prefix = struct.pack('I', len(response)) # 響應長度前綴 conn.sendall(length_prefix) conn.sendall(response)if __name__ == ’__main__’: sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 創建一個TCP套接字 sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) # 打開reuse addr選項 sock.bind(('localhost', 8080)) # 綁定端口 sock.listen(1) # 監聽客戶端連接 handlers = { # 注冊請求處理器 'ping': ping } loop(sock, handlers) # 進入服務循環

通過實例解析Python RPC實現原理及方法

多線程同步

使用線程庫thread創建原生線程 服務器可并行處理多個客戶端

服務端 multithread.py

通過實例解析Python RPC實現原理及方法

多進程同步

Python的GIL導致單個進程只能占滿一個CPU核心,多線程無法利用多核優勢 os.fork()會生成子進程 子進程退出后,父進程需使用waitpid系統調用收割子進程,防止其稱為僵尸資源 在子進程中關閉服務器套接字后,在父進程中也要關閉服務器套接字 因為進程fork后,父子進程都有自己的套接字引用指向內核的同一份套接字對象,套接字引用計數為2,對套接字進程close,即將套接字對象的引用計數減1

PreForking同步

進程比線程耗費資源,通過PreForking進程池模型對服務器開辟的進程數量進行限制,避免服務器負載過重 如果并行的連接數量超過了prefork進程數量,后來的客戶端請求將會阻塞

單進程異步

通過事件輪詢API,查詢相關套接字是否有響應的讀寫事件,有則攜帶事件列表返回,沒有則阻塞 拿到讀寫事件后,可對事件相關的套接字進行讀寫操作 設置讀寫緩沖區 Nginx/Nodejs/Redis都是基于異步模型 異步模型編碼成本高,易出錯,通常在公司業務代碼中采用同步模型,僅在講究高并發高性能的場合才使用異步模型

PreForking異步

Tornado/Nginx采用了多進程PreForking異步模型,具有良好的高并發處理能力

通過實例解析Python RPC實現原理及方法

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

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久国产福利| 国产精品一二| 中文字幕在线官网| 五月激情久久| 日韩精品一区二区三区免费观影| 国产精品亚洲欧美| 久久激情综合网| 国产精品主播在线观看| 免费亚洲一区| 欧美日韩视频网站| 国产农村妇女精品一二区| 亚洲综合婷婷| 日韩欧美2区| 精品国产一区二区三区av片| 久久蜜桃精品| 日韩中文字幕视频网| 免费在线亚洲| 国产高清久久| 国产欧美日韩精品一区二区免费 | 亚洲免费网址| 三级在线观看一区二区| 欧美日韩xxxx| 欧美sss在线视频| 日韩一区二区三区在线看| 成人精品视频| 亚洲一区二区日韩| 精品国产18久久久久久二百| 狠狠爱成人网| 欧美精品1区| 91九色精品| 国产精品v亚洲精品v日韩精品| 香蕉久久久久久久av网站| 欧美一区激情| 电影91久久久| 亚洲一区二区三区四区电影 | 久久xxx视频| 日韩和的一区二在线| 免费日本视频一区| 精品视频一区二区三区四区五区| 91伊人久久| 视频在线不卡免费观看| 亚洲一区免费| 国产不卡人人| 欧美亚洲tv| aa亚洲婷婷| 亚洲黄色中文字幕| 国产精一区二区| 一区二区精彩视频| 久久久久91| 国产美女久久| 视频一区二区不卡| 久久国产小视频| 精品精品国产三级a∨在线| 亚洲一二av| 亚洲一级影院| 手机在线电影一区| 欧美成a人片免费观看久久五月天| 日韩欧乱色一区二区三区在线| 日韩午夜一区| 日本一区二区高清不卡| 奇米狠狠一区二区三区| 亚洲欧美日韩视频二区| 999久久久精品国产| 国产极品模特精品一二| 日韩精品一二三四| 亚洲成人三区| 999国产精品永久免费视频app| 91精品1区| 亚洲天堂av影院| 久久亚洲人体| 日本麻豆一区二区三区视频| 精品1区2区3区4区| 欧美午夜精彩| 欧美少妇精品| 中文字幕人成乱码在线观看 | 欧美日韩精品免费观看视欧美高清免费大片 | 国产欧美一区二区精品久久久 | 亚洲tv在线| 日本国产精品| av日韩中文| 国产精品黑丝在线播放| 欧美91在线|欧美| 国产精品视频一区二区三区四蜜臂| 免费在线欧美黄色| 日本不卡高清| 日韩国产91| 亚洲一区二区三区中文字幕在线观看| 欧美影院视频| 亚洲精品激情| 日本午夜精品久久久久| 日本不卡不码高清免费观看| 亚洲精品美女91| 日韩精品久久久久久久软件91| 国产精品sss在线观看av| 亚洲一区二区三区在线免费| 亚洲人www| 奇米狠狠一区二区三区| 欧美亚洲一区二区三区| 国产剧情一区二区在线观看| 国产伦理一区| 国产精品嫩草影院在线看| 国产日产一区| 另类综合日韩欧美亚洲| 成人午夜在线| 欧美日韩色图| 视频一区二区国产| 亚洲69av| 欧美黄色一区二区| 成人日韩精品| 亚洲高清av| 久久www成人_看片免费不卡| 免费久久99精品国产| 日韩av一区二区在线影视| 麻豆国产精品777777在线| 成人亚洲一区二区| 亚洲精品国产偷自在线观看| 日韩在线成人| 国产一区二区三区四区五区| 99久久视频| 中文精品电影| 久久爱www成人| 亚洲视频综合| 亚洲精品进入| 成人精品视频| 视频一区中文字幕| 国产精品久久久久久久久久齐齐 | 国产超碰精品| 欧美高清一区| 日韩中文av| 高清在线一区| 欧美特黄a级高清免费大片a级| 精品视频亚洲| 久久久成人网| 石原莉奈在线亚洲三区| 国产精品日韩精品在线播放| 成人日韩在线观看| 亚洲视频播放| 国产探花在线精品| 999久久久国产精品| 日韩精品免费观看视频| 92国产精品| 日韩一二三区在线观看| 国产中文在线播放| 中文字幕亚洲精品乱码| 九九九精品视频| 香蕉久久久久久久av网站| 精品中文字幕一区二区三区四区| 日韩视频1区| 国产 日韩 欧美 综合 一区| 精品一区在线| 国产精品羞羞答答在线观看| sm久久捆绑调教精品一区| 蜜臀精品久久久久久蜜臀| 久久一区亚洲| 亚洲天堂免费| 99久久夜色精品国产亚洲1000部| 日韩三区免费| 丝袜亚洲另类欧美| 超碰成人av| 91综合久久爱com| 国产精品视区| 国产日韩电影| 国产精品久久久久av蜜臀| 在线午夜精品| 婷婷激情一区| 国产一区二区三区国产精品| 午夜亚洲精品| 日韩在线观看一区| 国产精品www.| 日本a级不卡| 一区二区国产在线| 在线综合亚洲| 亚洲大片在线| 高清不卡亚洲| 成午夜精品一区二区三区软件| 岛国av免费在线观看| 少妇精品久久久一区二区三区| 青青青国产精品| 一区久久精品| 成人羞羞视频播放网站| 国产日韩一区二区三区在线播放| 久久精品97| 蜜臀av性久久久久蜜臀aⅴ流畅| 日本伊人午夜精品| 中文精品在线| 黄色欧美日韩| 欧美在线资源| 欧美大黑bbbbbbbbb在线| 日本欧美不卡| 岛国av在线网站| 国产精品亚洲人成在99www| 亚久久调教视频| 亚洲综合婷婷| 中文字幕一区二区三区在线视频| 国产精品亚洲欧美一级在线| 欧美在线亚洲| 久久激情中文| 日韩啪啪电影网| 播放一区二区| 99精品电影|