久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

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

Python bsonrpc源碼解讀

瀏覽:120日期:2022-06-25 08:53:42

bsonrpc 是python中⼀個基于json或bson的遠程過程調⽤的庫,提供了服務端與客戶端實現,其底層采⽤的是基于TCP連接的通信。

程序結構

Python bsonrpc源碼解讀

bsonrpc主要包括以下⽂件:

concurrent.py:針對兩種并發⽅式(threading線程對象、gevent協程對象)涉及的相應組件(Queue,Event,Lock等)提供統⼀的對外的⽣成接⼝:spawn(),new_promise(),new_queue(), new_lock()等; definitions.py:定義rpc的消息結構和錯誤編碼; dispatcher.py:rpc的處理調度,路由處理(消息對應的處理函數); exceptions.py:異常定義; framing.py:定義不同類實現JSON RPC 2.0標準中的不同消息結構; interfaces.py:定義提供服務的裝飾器; misc.py:該⽂件中定義了⼀個id⽣成器,從1開始累加。 options.py:定義配置選項。 rpc.py:主要為BSONRpc和JSONRpc類的實現; socket_queue.py:主要為消息的拆包組包部分; util.py:系統⼯具。

本⽂主要描述庫包中對于不同協議的分包組包的處理,涉及到socket_queue.py和framing.py⽂件,主要采⽤的是對象組合的技術。

解讀

socket_queue.py中的SocketQueue類是⽤來處理從socket接收數據,主要的⽅法為_receiver()和put()⽅法,分別對應分包和組包,分包的主要內容如下:

def _receiver(self): bbuffer = b’’ while True: try: chunk = self.socket.recv(self.BUFSIZE) # 從socket上接收數據 bbuffer = self._to_queue(bbuffer + chunk) # 數據分包 except DecodingError as e: self._queue.put(e) # 后⾯省略...def _to_queue(self, bbuffer): b_msg, bbuffer = self.codec.extract_message(bbuffer) # 解碼器提取完整的信息 while b_msg is not None: self._queue.put(self.codec.loads(b_msg)) # 解碼后的消息放⼊消息隊列中等待處理 b_msg, bbuffer = self.codec.extract_message(bbuffer) return bbuffer

組包的主要內容如下:

def put(self, item): if self._closed: raise BsonRpcError(’Attempt to put items to closed queue.’) msg_bytes = self.codec.into_frame(self.codec.dumps(item)) # 組包 with self._lock: self.socket.sendall(msg_bytes)

Python bsonrpc源碼解讀

如上圖所示,程序采⽤的是對象組合的⽅式實現消息分包處理的。對象組合是繼承之外的另⼀種選擇,對象組合要求被組合的對象具有良好定義的接⼝,通過接⼝的⽅式調⽤其他對象的功能,這個也被“⿊箱復⽤”,因為對象的內部細節是不可⻅的。SocketQueue中依賴Codec的extract_message()接⼝⽅法,不⽤關⼼其具體的實現⽅法。具體實現由JSONCodec和BSONCode進⾏實現。JSONCodec中依賴JSONFrame中的extract_message()接⼝⽅法,該接⼝⽅法的實現由JSONFramingNone、JSONFramingNetstring、JSONFramingRFC7464進⾏實現。SocketQueue消息組包過程依賴于into_frame()⽅法,也是通過對象組合實現的。

注:圖中的接⼝為了⼤家容易理解才加上了,源碼⾥⾯并沒有。

以上就是Python bsonrpc源碼解讀的詳細內容,更多關于Python bsonrpc源碼的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 贞丰县| 上蔡县| 富川| 布拖县| 古交市| 乌拉特后旗| 敖汉旗| 东宁县| 朝阳市| 明水县| 霸州市| 城固县| 江口县| 克什克腾旗| 盱眙县| 锡林浩特市| 黎城县| 临洮县| 六枝特区| 左权县| 土默特右旗| 外汇| 聊城市| 子长县| 大关县| 察隅县| 肥乡县| 勃利县| 呼和浩特市| 响水县| 阳原县| 阿合奇县| 香河县| 师宗县| 连城县| 西城区| 离岛区| 凤凰县| 青田县| 康定县| 双城市|