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

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

Python如何實現遠程方法調用

瀏覽:31日期:2022-07-14 17:30:50

問題

你想在一個消息傳輸層如 sockets 、multiprocessing connections 或 ZeroMQ 的基礎之上實現一個簡單的遠程過程調用(RPC)。

解決方案

將函數請求、參數和返回值使用pickle編碼后,在不同的解釋器直接傳送pickle字節字符串,可以很容易的實現RPC。 下面是一個簡單的PRC處理器,可以被整合到一個服務器中去:

# rpcserver.pyimport pickleclass RPCHandler: def __init__(self): self._functions = { } def register_function(self, func): self._functions[func.__name__] = func def handle_connection(self, connection): try: while True:# Receive a messagefunc_name, args, kwargs = pickle.loads(connection.recv())# Run the RPC and send a responsetry: r = self._functions[func_name](*args,**kwargs) connection.send(pickle.dumps(r))except Exception as e: connection.send(pickle.dumps(e)) except EOFError: pass

要使用這個處理器,你需要將它加入到一個消息服務器中。你有很多種選擇, 但是使用 multiprocessing 庫是最簡單的。下面是一個RPC服務器例子:

from multiprocessing.connection import Listenerfrom threading import Threaddef rpc_server(handler, address, authkey): sock = Listener(address, authkey=authkey) while True: client = sock.accept() t = Thread(target=handler.handle_connection, args=(client,)) t.daemon = True t.start()# Some remote functionsdef add(x, y): return x + ydef sub(x, y): return x - y# Register with a handlerhandler = RPCHandler()handler.register_function(add)handler.register_function(sub)# Run the serverrpc_server(handler, (’localhost’, 17000), authkey=b’peekaboo’)

為了從一個遠程客戶端訪問服務器,你需要創建一個對應的用來傳送請求的RPC代理類。例如

import pickleclass RPCProxy: def __init__(self, connection): self._connection = connection def __getattr__(self, name): def do_rpc(*args, **kwargs): self._connection.send(pickle.dumps((name, args, kwargs))) result = pickle.loads(self._connection.recv()) if isinstance(result, Exception):raise result return result return do_rpc

要使用這個代理類,你需要將其包裝到一個服務器的連接上面,例如:

>>> from multiprocessing.connection import Client>>> c = Client((’localhost’, 17000), authkey=b’peekaboo’)>>> proxy = RPCProxy(c)>>> proxy.add(2, 3)5>>> proxy.sub(2, 3)-1>>> proxy.sub([1, 2], 4)Traceback (most recent call last): File '<stdin>', line 1, in <module> File 'rpcserver.py', line 37, in do_rpc raise resultTypeError: unsupported operand type(s) for -: ’list’ and ’int’>>>

要注意的是很多消息層(比如 multiprocessing )已經使用pickle序列化了數據。 如果是這樣的話,對 pickle.dumps() 和 pickle.loads() 的調用要去掉。

討論

RPCHandler 和 RPCProxy 的基本思路是很比較簡單的。 如果一個客戶端想要調用一個遠程函數,比如 foo(1, 2, z=3) ,代理類創建一個包含了函數名和參數的元組 (’foo’, (1, 2), {’z’: 3}) 。 這個元組被pickle序列化后通過網絡連接發生出去。 這一步在 RPCProxy 的 __getattr__() 方法返回的 do_rpc() 閉包中完成。 服務器接收后通過pickle反序列化消息,查找函數名看看是否已經注冊過,然后執行相應的函數。 執行結果(或異常)被pickle序列化后返回發送給客戶端。我們的實例需要依賴 multiprocessing 進行通信。 不過,這種方式可以適用于其他任何消息系統。例如,如果你想在ZeroMQ之上實習RPC, 僅僅只需要將連接對象換成合適的ZeroMQ的socket對象即可。

由于底層需要依賴pickle,那么安全問題就需要考慮了 (因為一個聰明的黑客可以創建特定的消息,能夠讓任意函數通過pickle反序列化后被執行)。 因此你永遠不要允許來自不信任或未認證的客戶端的RPC。特別是你絕對不要允許來自Internet的任意機器的訪問, 這種只能在內部被使用,位于防火墻后面并且不要對外暴露。

作為pickle的替代,你也許可以考慮使用JSON、XML或一些其他的編碼格式來序列化消息。 例如,本機實例可以很容易的改寫成JSON編碼方案。還需要將 pickle.loads() 和 pickle.dumps() 替換成 json.loads() 和 json.dumps() 即可:

# jsonrpcserver.pyimport jsonclass RPCHandler: def __init__(self): self._functions = { } def register_function(self, func): self._functions[func.__name__] = func def handle_connection(self, connection): try: while True:# Receive a messagefunc_name, args, kwargs = json.loads(connection.recv())# Run the RPC and send a responsetry: r = self._functions[func_name](*args,**kwargs) connection.send(json.dumps(r))except Exception as e: connection.send(json.dumps(str(e))) except EOFError: pass# jsonrpcclient.pyimport jsonclass RPCProxy: def __init__(self, connection): self._connection = connection def __getattr__(self, name): def do_rpc(*args, **kwargs): self._connection.send(json.dumps((name, args, kwargs))) result = json.loads(self._connection.recv()) return result return do_rpc

實現RPC的一個比較復雜的問題是如何去處理異常。至少,當方法產生異常時服務器不應該奔潰。 因此,返回給客戶端的異常所代表的含義就要好好設計了。 如果你使用pickle,異常對象實例在客戶端能被反序列化并拋出。如果你使用其他的協議,那得想想另外的方法了。 不過至少,你應該在響應中返回異常字符串。我們在JSON的例子中就是使用的這種方式。

以上就是Python如何實現遠程方法調用的詳細內容,更多關于Python遠程方法調用的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
麻豆精品在线观看| 日韩精品欧美成人高清一区二区| 国产欧美日韩| 亚洲欧美日韩视频二区| 欧美日韩国产精品一区二区亚洲| 亚洲二区视频| 色乱码一区二区三区网站| 国产精品最新| 精品一区二区三区中文字幕 | 久久的色偷偷| 精品一区二区三区亚洲| 中文字幕在线视频网站| 久久精品一区二区不卡| 91九色精品| 丝袜美腿亚洲一区二区图片| 三级久久三级久久久| 蜜桃久久精品一区二区| 日韩精品免费视频一区二区三区| 国产欧美啪啪| 亚洲综合电影| 亚洲综合二区| 国产探花一区在线观看| 久久精品午夜| 欧洲av一区二区| 鲁大师影院一区二区三区| 四虎在线精品| 美女久久99| 久久国产免费| 亚洲免费福利一区| 人在线成免费视频| 日韩午夜高潮| 婷婷久久免费视频| 久久国产精品免费一区二区三区 | 日韩精品欧美大片| 日本欧美国产| 欧美aa在线视频| 国产精品视频一区二区三区 | 日韩国产欧美在线视频| 国产美女久久| 免费在线观看一区| 久久亚洲成人| 日韩av一区二区三区四区| 久久麻豆视频| 欧美a级一区| 国产欧美激情| 亚洲手机在线| 国产精选一区| 在线看片福利| 欧美日韩国产欧| 日本aⅴ免费视频一区二区三区| 久久免费福利| 亚洲精品1区| 欧美国产精品| 黄色日韩在线| 日韩欧美高清一区二区三区| 国产精品原创| 日韩精品一页| 精品一区二区三区中文字幕| 99国产精品免费视频观看| 在线精品视频一区| 精品一级视频| 综合色一区二区| 韩国精品主播一区二区在线观看| 亚洲1区在线观看| 欧洲亚洲一区二区三区| 日韩动漫一区| 亚洲精品2区| 欧美日韩少妇| 美女毛片一区二区三区四区最新中文字幕亚洲| 亚洲色图网站| 欧美性www| 久久国产电影| 日韩欧美在线精品| 欧美日韩一二三四| 日本视频中文字幕一区二区三区| 加勒比视频一区| 国产精品蜜芽在线观看| 亚洲欧美日韩国产综合精品二区| 成人黄色av| 国产精品国码视频| 亚州国产精品| 爽好久久久欧美精品| 欧美日韩在线二区| 久久97视频| 日本欧洲一区二区| 亚洲一级特黄| 成人羞羞视频播放网站| 成人亚洲精品| 欧美日韩午夜电影网| 丝袜美腿亚洲色图| 久久理论电影| 日韩国产专区| 精品一区二区三区中文字幕| 日韩欧美久久| 三级欧美在线一区| 亚洲精品午夜av福利久久蜜桃| 成人美女视频| 国产成人免费| 国产欧美一区| 综合国产在线| 蜜桃视频在线观看一区二区| 国产精品婷婷| 香蕉精品久久| 久久九九电影| 成人久久久久| 激情视频网站在线播放色| 九九久久国产| 精品国产精品国产偷麻豆| 国产精品久久久久av蜜臀| 日韩精品欧美成人高清一区二区| 喷白浆一区二区| 亚洲制服少妇| 美女久久网站| 最新国产拍偷乱拍精品| 亚洲一级网站| 蜜臀av免费一区二区三区| 久久精品国语| 婷婷综合亚洲| 日韩一级精品| 免费高清在线一区| 日韩三级一区| 欧美一级网站| 国产欧美日韩一区二区三区四区| 国产毛片精品| 久久亚洲人体| 九九九精品视频| 日本一区二区免费高清| 亚洲啊v在线| 欧美91视频| 欧美日韩一二三四| 亚洲欧洲一区| 亚洲精品九九| 国产欧美日韩视频在线| 精品一区二区三区中文字幕视频| 国产一区二区三区免费在线| 福利在线一区| 欧美亚洲在线日韩| 久久福利影视| 日韩精选在线| 麻豆精品少妇| 日韩中文在线播放| 91久久中文| 日韩高清不卡在线| 久久影院一区二区三区| sm久久捆绑调教精品一区| 久久久久中文| 国产精品视区| 欧美亚洲人成在线| 国产一区二区精品福利地址| 中文字幕在线高清| 国产伊人精品| 中文字幕日韩亚洲| 国产麻豆一区二区三区精品视频| 国产999精品在线观看| 久久久水蜜桃av免费网站| 亚洲在线观看| 国产视频一区二区在线播放| 福利欧美精品在线| 国产综合欧美| 亚洲不卡视频| 成人在线视频区| 99热精品在线观看| 久久激五月天综合精品| 天堂av在线| 石原莉奈在线亚洲三区| 国产精品白丝久久av网站| 久久免费国产| 日韩精品三级| 日韩不卡免费高清视频| 免费成人在线视频观看| 麻豆精品在线| 欧美 日韩 国产一区二区在线视频 | 青青草精品视频| 国产精品成人a在线观看| 免费视频久久| 精品伊人久久久| 久久先锋影音| 高清久久精品| 欧美资源在线| 精品国产精品国产偷麻豆| 中文欧美日韩| 久久久91麻豆精品国产一区| 狠狠干成人综合网| 你懂的国产精品| 免费日韩视频| 久久影院午夜精品| 男人的天堂久久精品| 美女毛片一区二区三区四区最新中文字幕亚洲 | 图片区亚洲欧美小说区| 91国内精品| 久久亚洲风情| 热三久草你在线| 国产精品.xx视频.xxtv| 一区久久精品| 丝袜美腿诱惑一区二区三区 | 不卡视频在线| 夜鲁夜鲁夜鲁视频在线播放| 麻豆91精品视频| 青草久久视频| 男人的天堂亚洲一区|