电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

Python 如何創建一個線程池

瀏覽:145日期:2022-07-16 09:33:48

問題

你創建一個工作者線程池,用來響應客戶端請求或執行其他的工作。

解決方案

concurrent.futures 函數庫有一個 ThreadPoolExecutor 類可以被用來完成這個任務。 下面是一個簡單的TCP服務器,使用了一個線程池來響應客戶端:

from socket import AF_INET, SOCK_STREAM, socketfrom concurrent.futures import ThreadPoolExecutordef echo_client(sock, client_addr): ’’’ Handle a client connection ’’’ print(’Got connection from’, client_addr) while True: msg = sock.recv(65536) if not msg: break sock.sendall(msg) print(’Client closed connection’) sock.close()def echo_server(addr): pool = ThreadPoolExecutor(128) sock = socket(AF_INET, SOCK_STREAM) sock.bind(addr) sock.listen(5) while True: client_sock, client_addr = sock.accept() pool.submit(echo_client, client_sock, client_addr)echo_server((’’,15000))

如果你想手動創建你自己的線程池, 通常可以使用一個Queue來輕松實現。下面是一個稍微不同但是手動實現的例子:

from socket import socket, AF_INET, SOCK_STREAMfrom threading import Threadfrom queue import Queuedef echo_client(q): ’’’ Handle a client connection ’’’ sock, client_addr = q.get() print(’Got connection from’, client_addr) while True: msg = sock.recv(65536) if not msg: break sock.sendall(msg) print(’Client closed connection’) sock.close()def echo_server(addr, nworkers): # Launch the client workers q = Queue() for n in range(nworkers): t = Thread(target=echo_client, args=(q,)) t.daemon = True t.start() # Run the server sock = socket(AF_INET, SOCK_STREAM) sock.bind(addr) sock.listen(5) while True: client_sock, client_addr = sock.accept() q.put((client_sock, client_addr))echo_server((’’,15000), 128)

使用 ThreadPoolExecutor 相對于手動實現的一個好處在于它使得 任務提交者更方便的從被調用函數中獲取返回值。例如,你可能會像下面這樣寫:

from concurrent.futures import ThreadPoolExecutorimport urllib.requestdef fetch_url(url): u = urllib.request.urlopen(url) data = u.read() return datapool = ThreadPoolExecutor(10)# Submit work to the poola = pool.submit(fetch_url, ’http://www.python.org’)b = pool.submit(fetch_url, ’http://www.pypy.org’)# Get the results backx = a.result()y = b.result()

例子中返回的handle對象會幫你處理所有的阻塞與協作,然后從工作線程中返回數據給你。 特別的,a.result() 操作會阻塞進程直到對應的函數執行完成并返回一個結果。

討論

通常來講,你應該避免編寫線程數量可以無限制增長的程序。例如,看看下面這個服務器:

from threading import Threadfrom socket import socket, AF_INET, SOCK_STREAMdef echo_client(sock, client_addr): ’’’ Handle a client connection ’’’ print(’Got connection from’, client_addr) while True: msg = sock.recv(65536) if not msg: break sock.sendall(msg) print(’Client closed connection’) sock.close()def echo_server(addr, nworkers): # Run the server sock = socket(AF_INET, SOCK_STREAM) sock.bind(addr) sock.listen(5) while True: client_sock, client_addr = sock.accept() t = Thread(target=echo_client, args=(client_sock, client_addr)) t.daemon = True t.start()echo_server((’’,15000))

盡管這個也可以工作, 但是它不能抵御有人試圖通過創建大量線程讓你服務器資源枯竭而崩潰的攻擊行為。 通過使用預先初始化的線程池,你可以設置同時運行線程的上限數量。

你可能會關心創建大量線程會有什么后果。 現代操作系統可以很輕松的創建幾千個線程的線程池。 甚至,同時幾千個線程等待工作并不會對其他代碼產生性能影響。 當然了,如果所有線程同時被喚醒并立即在CPU上執行,那就不同了——特別是有了全局解釋器鎖GIL。 通常,你應該只在I/O處理相關代碼中使用線程池。

創建大的線程池的一個可能需要關注的問題是內存的使用。 例如,如果你在OS X系統上面創建2000個線程,系統顯示Python進程使用了超過9GB的虛擬內存。 不過,這個計算通常是有誤差的。當創建一個線程時,操作系統會預留一個虛擬內存區域來 放置線程的執行棧(通常是8MB大小)。但是這個內存只有一小片段被實際映射到真實內存中。 因此,Python進程使用到的真實內存其實很小 (比如,對于2000個線程來講,只使用到了70MB的真實內存,而不是9GB)。 如果你擔心虛擬內存大小,可以使用 threading.stack_size() 函數來降低它。例如:

import threadingthreading.stack_size(65536)

如果你加上這條語句并再次運行前面的創建2000個線程試驗, 你會發現Python進程只使用到了大概210MB的虛擬內存,而真實內存使用量沒有變。 注意線程棧大小必須至少為32768字節,通常是系統內存頁大小(4096、8192等)的整數倍。

以上就是Python 如何創建一個線程池的詳細內容,更多關于Python 創建線程池的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 发电机价格|发电机组价格|柴油发电机价格|柴油发电机组价格网 | 热风机_工业热风机生产厂家上海冠顶公司提供专业热风机图片价格实惠 | 有机肥设备生产制造厂家,BB掺混肥搅拌机、复合肥设备生产线,有机肥料全部加工设备多少钱,对辊挤压造粒机,有机肥造粒设备 -- 郑州程翔重工机械有限公司 | 橡胶电子拉力机-塑料-微电脑电子拉力试验机厂家-江苏天源 | 预制直埋蒸汽保温管-直埋管道-聚氨酯发泡保温管厂家 - 唐山市吉祥保温工贸有限公司 | 锤式粉碎机,医药粉碎机,锥式粉碎机-无锡市迪麦森机械制造有限公司 | 高铝轻质保温砖_刚玉莫来石砖厂家_轻质耐火砖价格 | 厚壁钢管-厚壁无缝钢管-小口径厚壁钢管-大口径厚壁钢管 - 聊城宽达钢管有限公司 | 热闷罐-高温罐-钢渣热闷罐-山东鑫泰鑫智能热闷罐厂家 | 安徽控制器-合肥船用空调控制器-合肥家电控制器-合肥迅驰电子厂 安徽净化板_合肥岩棉板厂家_玻镁板厂家_安徽科艺美洁净科技有限公司 | 早报网| 游泳池设计|设备|配件|药品|吸污机-东莞市太平洋康体设施有限公司 | 电动不锈钢套筒阀-球面偏置气动钟阀-三通换向阀止回阀-永嘉鸿宇阀门有限公司 | 杜康白酒加盟_杜康酒代理_杜康酒招商加盟官网_杜康酒厂加盟总代理—杜康酒神全国运营中心 | [品牌官网]贵州遵义双宁口腔连锁_贵州遵义牙科医院哪家好_种植牙_牙齿矫正_原华美口腔 | 低粘度纤维素|混凝土灌浆料|有机硅憎水粉|聚羧酸减水剂-南京斯泰宝 | 河南mpp电力管_mpp电力管生产厂家_mpp电力电缆保护管价格 - 河南晨翀实业 | OpenI 启智 新一代人工智能开源开放平台 | elisa试剂盒-PCR试剂盒「上海谷研实业有限公司」 | 玻璃钢板-玻璃钢防腐瓦-玻璃钢材料-广东壹诺 | 首页_欧瑞传动官方网站--主营变频器、伺服系统、新能源、软起动器、PLC、HMI | 【灵硕展览集团】展台展会设计_展览会展台搭建_展览展示设计一站式服务公司 | 今日热点_实时热点_奇闻异事_趣闻趣事_灵异事件 - 奇闻事件 | 膜结构车棚|上海膜结构车棚|上海车棚厂家|上海膜结构公司 | 3d可视化建模_三维展示_产品3d互动数字营销_三维动画制作_3D虚拟商城 【商迪3D】三维展示服务商 广东健伦体育发展有限公司-体育工程配套及销售运动器材的体育用品服务商 | 喷码机,激光喷码打码机,鸡蛋打码机,手持打码机,自动喷码机,一物一码防伪溯源-恒欣瑞达有限公司 | 青岛球场围网,青岛车间隔离网,青岛机器人围栏,青岛水源地围网,青岛围网,青岛隔离栅-青岛晟腾金属制品有限公司 | 地磅-地秤-江阴/无锡地磅-江阴天亿计量设备有限公司_ | 冷藏车厂家|冷藏车价格|小型冷藏车|散装饲料车厂家|程力专用汽车股份有限公司销售十二分公司 | 网优资讯-为循环资源、大宗商品、工业服务提供资讯与行情分析的数据服务平台 | 置顶式搅拌器-优莱博化学防爆冰箱-磁驱搅拌器-天津市布鲁克科技有限公司 | 中式装修设计_室内中式装修_【云臻轩】中式设计机构 | 石磨面粉机|石磨面粉机械|石磨面粉机组|石磨面粉成套设备-河南成立粮油机械有限公司 | 武汉不干胶印刷_标签设计印刷_不干胶标签印刷厂 - 武汉不干胶标签印刷厂家 | TwistDx恒温扩增-RAA等温-Jackson抗体-默瑞(上海)生物科技有限公司 | 防水套管|柔性防水套管|伸缩器|伸缩接头|传力接头-河南伟创管道 防水套管_柔性防水套管_刚性防水套管-巩义市润达管道设备制造有限公司 | 软膜天花_软膜灯箱_首选乐创品牌_一站式天花软膜材料供应商! | 政府园区专业委托招商平台_助力企业选址项目快速落地_东方龙商务集团 | 固诺家居-全屋定制十大品牌_整体衣柜木门橱柜招商加盟 | 电动垃圾车,垃圾清运车-江苏速利达机车有限公司 | 金属雕花板_厂家直销_价格低-山东慧诚建筑材料有限公司 |