亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

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

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

瀏覽:2日期:2022-07-02 10:35:32
多進(jìn)程&多線程

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

缺點(diǎn):<1> 由于Cpython的GIL,導(dǎo)致同一時(shí)間無(wú)法運(yùn)行多個(gè)線程;<2> 不可能無(wú)限開進(jìn)進(jìn)程或線程

解決辦法:多進(jìn)程、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)建一個(gè)進(jìn)程 p.start()# 告訴操作提供,開啟這個(gè)進(jìn)程進(jìn)程池&線程池

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

優(yōu)點(diǎn):簡(jiǎn)化socket服務(wù)端創(chuàng)建流程。提供服務(wù)端串行和并發(fā)兩種服務(wù)模式(TCPServer,ThreadingTCPServer)缺點(diǎn):windows上無(wú)法使用多進(jìn)程實(shí)現(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)點(diǎn):?jiǎn)尉€程內(nèi)實(shí)現(xiàn)并發(fā),代碼級(jí)別模擬IO切換,提高程序運(yùn)行效率

from gevent import spawn, monkey;monkey.patch_all()# 猴子補(bǔ)丁,補(bǔ)丁:常規(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)# 檢測(cè) 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)# 檢測(cè)wait_accept的io g1.join()# 等待g1運(yùn)行結(jié)束,即一直在循環(huán)檢測(cè)io

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

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 成年人看的黄色片 | 夜色视频一区二区三区 | 在线亚洲一区二区 | 色多多最新地址福利地址 | 91精品国产综合久久久久 | 精品国产综合区久久久久久 | 国产日产亚洲系列首页 | 久久精品国产这里是免费 | 成人爱做日本视频免费 | 91视频久久 | 欧美成人怡红院在线观看 | 国产手机在线视频放线视频 | 欧美国产大片 | 久久精品视频免费 | 亚洲精品久久一区二区无卡 | 天堂一区二区三区在线观看 | 夜色成人免费观看 | 图片区偷拍区小说区 | 美女视频黄a全部免费专区一 | 国产一区二区三区四区五区tv | 欧美做爰孕妇群 | 国产99视频精品一区 | 欧美日韩一日韩一线不卡 | 久草最新在线 | 国产成人一区二区三区精品久久 | 亚洲视频国产精品 | 亚洲精品视频免费看 | 亚洲欧美日本人成在线观看 | 91久久青青草原线免费 | 免费播放国产性色生活片 | 香蕉亚洲精品一区二区 | 久久er国产精品免费观看1 | 亚洲一区在线观看视频 | 国产成人a一在线观看 | 在线a人片免费观看国产 | 香港三级日本三级三级人妇 | 波野多衣在线观 | 日本久草视频 | 麻豆国产| 91九色国产 | 久久久久在线 |