色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

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

python 實現socket服務端并發的四種方式

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

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

缺點:<1> 由于Cpython的GIL,導致同一時間無法運行多個線程;<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, ))# 創建一個進程 p.start()# 告訴操作提供,開啟這個進程進程池&線程池

異步提交任務,支持異步接收返回結果(submit返回一個futures對象,調用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個進程一直服務 while 1: conn, addr = server.wait_accept() pool.submit(server.handle_request, conn)# 異步提交任務socketserver

優點:簡化socket服務端創建流程。提供服務端串行和并發兩種服務模式(TCPServer,ThreadingTCPServer)缺點:windows上無法使用多進程實現并發

import socketserverclass MyTcpHandler(socketserver.BaseRequestHandler): def handle(self):# 通信循環 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()# 連接循環

協程

優點:單線程內實現并發,代碼級別模擬IO切換,提高程序運行效率

from gevent import spawn, monkey;monkey.patch_all()# 猴子補丁,補丁:常規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運行結束,即一直在循環檢測io

以上就是python 實現socket服務端并發的四種方式的詳細內容,更多關于python socket服務端并發的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 三级做人爱c视频18三级 | 色吊丝avav色吊丝 | 91一级片 | 国产在线黄 | 久久精品国产国产精品四凭 | se视频在线观看 | 久久久精品一区二区三区 | 九九精品免费视频 | 日本久久综合网 | 黄色片日本人 | 亚洲手机看片 | 国产91无套剧情在线播放 | 免费一级欧美性大片 | 久草视频免费在线看 | 日本国产一区二区三区 | 久久欧洲视频 | 亚洲 欧美 激情 另类 自拍 | 国产91网址 | 亚洲精品一区亚洲精品 | 久久视频6免费观看视频精品 | 理伦毛片 | 国产精品欧美亚洲韩国日本不卡 | 精品国产中文一级毛片在线看 | 亚洲精品不卡在线 | 手机看片欧美 | 欧美日韩精品在线播放 | 成人免费视频一区 | 在线天堂视频 | 亚洲成人黄色在线观看 | 成人18视频在线 | a男人的天堂久久a毛片 | 欧美日韩国产高清一区二区三区 | 中文字幕成人免费高清在线 | 99视频免费看 | 国产菲菲视频在线观看 | 一级毛片在播放免费 | 国产精品短视频免费观看 | 精品国产网站 | 亚洲欧洲无码一区二区三区 | 日韩亚洲成a人片在线观看 日韩亚洲精品不卡在线 | 欧美aaa|