国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

python 實現(xiàn)socket服務(wù)端并發(fā)的四種方式

瀏覽:6日期:2022-07-02 10:35:32
多進程&多線程

服務(wù)端:多進程和多線程的開啟方式相同。

缺點:<1> 由于Cpython的GIL,導(dǎo)致同一時間無法運行多個線程;<2> 不可能無限開進進程或線程

解決辦法:多進程、concurrent.futures.ProcessPoolExecutor、線程池

import socketfrom multiprocessing import Processfrom threading import Threadclass MyTcpServer: def __init__(self, ip, port): self.ip = ip self.port = port self.server = socket.socket() self.server.bind((self.ip, self.port)) self.server.listen(5) def wait_accept(self): conn, addr = self.server.accept() return conn, addr def handle_request(self, conn): while 1: try:data = conn.recv(1024)if not data: breakconn.send(data.upper()) except Exception as e:print(e)break conn.close()if __name__ == ’__main__’: server = MyTcpServer(’127.0.0.1’, 8888) while 1: conn, addr = server.wait_accept() p = Process(target=server.handle_request, args=(conn, ))# 創(chuàng)建一個進程 p.start()# 告訴操作提供,開啟這個進程進程池&線程池

異步提交任務(wù),支持異步接收返回結(jié)果(submit返回一個futures對象,調(diào)用add_done_callback方法)

import socketfrom concurrent.futures import ProcessPoolExecutor# from concurrent.futures import ThreadPoolExecutorclass MyTcpServer: def __init__(self, ip, port): self.ip = ip self.port = port self.server = socket.socket() self.server.bind((self.ip, self.port)) self.server.listen(5) def wait_accept(self): conn, addr = self.server.accept() return conn, addr def handle_request(self, conn): while 1: try:data = conn.recv(1024)if not data: breakconn.send(data.upper()) except Exception as e:print(e)break conn.close()if __name__ == ’__main__’: server = MyTcpServer(’127.0.0.1’, 8888) pool = ProcessPoolExecutor(5) # 5個進程一直服務(wù) while 1: conn, addr = server.wait_accept() pool.submit(server.handle_request, conn)# 異步提交任務(wù)socketserver

優(yōu)點:簡化socket服務(wù)端創(chuàng)建流程。提供服務(wù)端串行和并發(fā)兩種服務(wù)模式(TCPServer,ThreadingTCPServer)缺點:windows上無法使用多進程實現(xiàn)并發(fā)

import socketserverclass MyTcpHandler(socketserver.BaseRequestHandler): def handle(self):# 通信循環(huán) while 1: try:data = self.request.recv(1024)if not data: breakself.request.send(data.upper()) except Exception as e:print(e)break self.request.close()if __name__ == ’__main__’: ip_port = ’127.0.0.1’, 8888 server = socketserver.ThreadingTCPServer(ip_port, MyTcpHandler) # 異步處理 server.serve_forever()# 連接循環(huán)

協(xié)程

優(yōu)點:單線程內(nèi)實現(xiàn)并發(fā),代碼級別模擬IO切換,提高程序運行效率

from gevent import spawn, monkey;monkey.patch_all()# 猴子補丁,補丁:常規(guī)IOimport socketclass MyTcpServer: def __init__(self, ip, port, my_spawn): self.ip = ip self.port = port self.server = socket.socket() self.server.bind((self.ip, self.port)) self.server.listen(5) self.spawn = my_spawn# 保存spawn本地 def wait_accept(self): while 1: conn, addr = self.server.accept() self.spawn(self.handle_request, conn)# 檢測 handle_request的io def handle_request(self, conn): while 1: try:data = conn.recv(1024)if not data: breakconn.send(data.upper()) except Exception as e:print(e)break conn.close()if __name__ == ’__main__’: server = MyTcpServer(’127.0.0.1’, 8888, spawn) g1 = server.spawn(server.wait_accept)# 檢測wait_accept的io g1.join()# 等待g1運行結(jié)束,即一直在循環(huán)檢測io

以上就是python 實現(xiàn)socket服務(wù)端并發(fā)的四種方式的詳細內(nèi)容,更多關(guān)于python socket服務(wù)端并發(fā)的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 日韩色视频一区二区三区亚洲 | 在线观看中文字幕国产 | 久久久久综合给合狠狠狠 | 日本一区二区三区四区不卡 | 三上悠亚免费一区二区在线 | 厕拍精品 | www成人在线观看 | 成人在线观看国产 | 国产精品1区2区3区 国产精品1区2区3区在线播放 | 91精品一区二区三区在线播放 | 国产乱淫视频 | 日韩成人精品日本亚洲 | 亚洲精品国产拍拍拍拍拍 | 国产91精品露脸国语对白 | 精品视自拍视频在线观看 | 亚洲天堂二区 | 免费观看女人一摸全是水 | 91视频久久 | 亚洲精品中文字幕在线 | 欧美亚洲国产成人精品 | 日韩欧美一区二区三区久久 | 中文字幕曰韩一区二区不卡 | 91精品综合久久久久m3u8 | 亚洲精品成人一区二区aⅴ 亚洲精品成人一区二区www | 麻豆国产 | 亚洲视频综合网 | 久久福利国产 | 久久国产热视频 | 日韩 亚洲 制服 欧美 综合 | 成人国产午夜在线视频 | 男人扒开双腿女人爽视频免费 | 欧美jizzhd精品欧美高清 | 欧美一区二区三区久久综合 | 亚洲国产精品网站久久 | 亚洲字幕波多野结衣作品 | aaaa级毛片 | 国产乱弄视频在线观看 | 中文字幕 亚洲 一区二区三区 | 国产精品毛片无码 | 亚洲三级黄色片 | 国产精品国产三级国产普通 |