Python線程池ThreadPoolExecutor使用方式
如何使用線程池?
實(shí)際案例
我們之前實(shí)現(xiàn)了一個(gè)多線程web視頻監(jiān)控服務(wù)器,我們需要對(duì)請(qǐng)求連接數(shù)做限制,以防止惡意用戶發(fā)起大量連接而導(dǎo)致服務(wù)器創(chuàng)建大量線程,最終因資源耗盡而癱瘓。
可以使用線程池,替代原來(lái)的每次請(qǐng)求創(chuàng)建線程。
解決方案
python3中有線程池實(shí)現(xiàn),使用標(biāo)準(zhǔn)庫(kù)中concurrent.futures下的ThreadPoolExecutor,對(duì)象的submit和map方法可以用來(lái)啟動(dòng)線程池中線程執(zhí)行任務(wù)。
線程池介紹:
線程池就是提前創(chuàng)建好某一固定數(shù)量的線程放到池子里面,需要使用的時(shí)候去這個(gè)池子中取一個(gè)線程出來(lái)讓它執(zhí)行任務(wù),執(zhí)行完以后再歸還給線程池以便后面的任務(wù)繼續(xù)使用線程。
代碼演示
多線程池的簡(jiǎn)單使用
from concurrent.futures import ThreadPoolExecutor # 創(chuàng)建Executor對(duì)象,指定線程池中線程數(shù) executor = ThreadPoolExecutor(3) # 使用線程池中線程執(zhí)行任務(wù) # 定義任務(wù)函數(shù)a的b次方 def f(a, b): print('f', a, b) return a ** b # 調(diào)用線程池中線程去執(zhí)行函數(shù) future = executor.submit(f, 2, 3) # 使用線程池中一個(gè)線程運(yùn)行這個(gè)函數(shù),這個(gè)函數(shù)運(yùn)行完以后 # 這個(gè)線程又會(huì)歸還到線程池中去 # 使用result得到函數(shù)的運(yùn)行結(jié)果 print(future.result()) # 如果函數(shù)的運(yùn)行事件比較長(zhǎng),在調(diào)用result的時(shí)候他還沒(méi)有執(zhí)行完, # 這個(gè)result就會(huì)被阻塞到這里,直到這個(gè)函數(shù)運(yùn)行完 # 和python內(nèi)置的map方法類似,只不過(guò)他在多個(gè)線程上同時(shí)調(diào)用f # 在第1個(gè)線程計(jì)算2的4次方,第2個(gè)線程計(jì)算3的5次方,第3個(gè)線程計(jì)算5的6次方 executor.map(f, [2, 3, 5], [4, 5, 6]) ''' 假設(shè)當(dāng)前線程池中所有線程都在忙碌,一直在運(yùn)行函數(shù)并且沒(méi)有返回, 我們?cè)偬峤灰粋€(gè)任務(wù)的時(shí)候,就會(huì)出現(xiàn)pending, 等待線程池中有一個(gè)空閑線程來(lái)運(yùn)行它。 ''' import time def f2(a, b): print('f2', a, b) time.sleep(10) # 等待10秒再返回 return a ** b # 運(yùn)行以下語(yǔ)句可以到,可以看到首先打印的'f2 2 4'、'f2 3 5'、'f2 5 6' # 過(guò)了一會(huì)才把'f2 6 7'和'f2 7 8'打印出來(lái),直到前面退出了他才得到運(yùn)行權(quán)利 executor.map(f2, [2, 3, 5, 6, 7], [4, 5, 6, 7, 8])
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
python3使用matplotlib繪制散點(diǎn)圖
這篇文章主要為大家詳細(xì)介紹了python3使用matplotlib繪制散點(diǎn)圖,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-03-03關(guān)于python中不同函數(shù)讀取圖片格式的區(qū)別淺析
這篇文章主要給大家介紹了關(guān)于python中不同函數(shù)讀取圖片格式的區(qū)別,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-03-03python使用json將字符串轉(zhuǎn)字典報(bào)錯(cuò)的解決
這篇文章主要介紹了python使用json將字符串轉(zhuǎn)字典報(bào)錯(cuò)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02利用Python實(shí)現(xiàn)自定義連點(diǎn)器
這篇文章主要介紹了如何利用Python實(shí)現(xiàn)自定義連點(diǎn)器,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08簡(jiǎn)單介紹Python的Django框架加載模版的方式
這篇文章主要介紹了Python的Django框架加載模版的方式,包括一些對(duì)加載順序的介紹,需要的朋友可以參考下2015-07-07Python的flask接收前臺(tái)的ajax的post數(shù)據(jù)和get數(shù)據(jù)的方法
這篇文章主要介紹了Python的flask接收前臺(tái)的ajax的post數(shù)據(jù)和get數(shù)據(jù)的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04