国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

      <sup id="hb9fh"></sup>
          1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

            手機(jī)站
            千鋒教育

            千鋒學(xué)習(xí)站 | 隨時隨地免費(fèi)學(xué)

            千鋒教育

            掃一掃進(jìn)入千鋒手機(jī)站

            領(lǐng)取全套視頻
            千鋒教育

            關(guān)注千鋒學(xué)習(xí)站小程序
            隨時隨地免費(fèi)學(xué)習(xí)課程

            當(dāng)前位置:首頁  >  技術(shù)干貨  > python 進(jìn)程池

            python 進(jìn)程池

            來源:千鋒教育
            發(fā)布人:xqq
            時間: 2023-11-08 03:07:36 1699384056

            在利用Python進(jìn)行系統(tǒng)管理的時候,特別是同時操作多個文件目錄,或者遠(yuǎn)程控制多臺主機(jī),并行操作可以節(jié)約大量的時間。多進(jìn)程是實(shí)現(xiàn)并發(fā)的手段之一,需要注意的問題是:

            1)很明顯需要并發(fā)執(zhí)行的任務(wù)通常要遠(yuǎn)大于核數(shù)

            2)一個操作系統(tǒng)不可能無限開啟進(jìn)程,通常有幾個核就開幾個進(jìn)程

            3)進(jìn)程開啟過多,效率反而會下降(開啟進(jìn)程是需要占用系統(tǒng)資源的,而且開啟多余核數(shù)目的進(jìn)程也無法做到并行)

            例如當(dāng)被操作對象數(shù)目不大時,可以直接利用multiprocessing中的Process動態(tài)成生多個進(jìn)程,十幾個還好,但如果是上百個,上千個。。。手動的去限制進(jìn)程數(shù)量卻又太過繁瑣,此時可以發(fā)揮進(jìn)程池的功效。

            我們就可以通過維護(hù)一個進(jìn)程池來控制進(jìn)程數(shù)目,比如httpd的進(jìn)程模式,規(guī)定最小進(jìn)程數(shù)和最大進(jìn)程數(shù)...

            對于遠(yuǎn)程過程調(diào)用的高級應(yīng)用程序而言,應(yīng)該使用進(jìn)程池,Pool可以提供指定數(shù)量的進(jìn)程,供用戶調(diào)用,當(dāng)有新的請求提交到pool中時,如果池還沒有滿,那么就會創(chuàng)建一個新的進(jìn)程用來執(zhí)行該請求;但如果池中的進(jìn)程數(shù)已經(jīng)達(dá)到規(guī)定最大值,那么該請求就會等待,直到池中有進(jìn)程結(jié)束,就重用進(jìn)程池中的進(jìn)程。

            創(chuàng)建進(jìn)程池的類:如果指定numprocess為3,則進(jìn)程池會從無到有創(chuàng)建三個進(jìn)程,然后自始至終使用這三個進(jìn)程去執(zhí)行所有任務(wù),不會開啟其他進(jìn)程

            1Pool([numprocess[,initializer[,initargs]]]):創(chuàng)建進(jìn)程池

            參數(shù)介紹:

            1numprocess:要創(chuàng)建的進(jìn)程數(shù),如果省略,將默認(rèn)使用cpu_count()的值

            2initializer:是每個工作進(jìn)程啟動時要執(zhí)行的可調(diào)用對象,默認(rèn)為None

            3initargs:是要傳給initializer的參數(shù)組

            主要方法:

            1p.apply(func[,args[,kwargs]])

            在一個池工作進(jìn)程中執(zhí)行func(*args,**kwargs),然后返回結(jié)果。

            需要強(qiáng)調(diào)的是:此操作并不會在所有池工作進(jìn)程中并執(zhí)行func函數(shù)。如果要通過不同參數(shù)并發(fā)地執(zhí)行func函數(shù),必須從不同線程調(diào)用p.apply()函數(shù)或者使用p.apply_async()

            2p.apply_async(func[,args[,kwargs]]):

            在一個池工作進(jìn)程中執(zhí)行func(*args,**kwargs),然后返回結(jié)果。

            此方法的結(jié)果是AsyncResult類的實(shí)例,callback是可調(diào)用對象,接收輸入?yún)?shù)。當(dāng)func的結(jié)果變?yōu)榭捎脮r,

            將理解傳遞給callback。callback禁止執(zhí)行任何阻塞操作,否則將接收其他異步操作中的結(jié)果。

            3p.close():關(guān)閉進(jìn)程池,防止進(jìn)一步操作。如果所有操作持續(xù)掛起,它們將在工作進(jìn)程終止前完成

            4P.jion():等待所有工作進(jìn)程退出。此方法只能在close()或teminate()之后調(diào)用

            應(yīng)用

            同步調(diào)用applay

            異步調(diào)用apply_async

            apply_async與apply詳解

            使用進(jìn)程池維護(hù)固定數(shù)目的進(jìn)程

            server端

            客戶端

            發(fā)現(xiàn):并發(fā)開啟多個客戶端,服務(wù)端同一時間只有3個不同的pid,干掉一個客戶端,另外一個客戶端才會進(jìn)來,被3個進(jìn)程之一處理

            回掉函數(shù):

            需要回調(diào)函數(shù)的場景:進(jìn)程池中任何一個任務(wù)一旦處理完了,就立即告知主進(jìn)程:我好了額,你可以處理我的結(jié)果了。主進(jìn)程則調(diào)用一個函數(shù)去處理該結(jié)果,該函數(shù)即回調(diào)函數(shù)

            我們可以把耗時間(阻塞)的任務(wù)放到進(jìn)程池中,然后指定回調(diào)函數(shù)(主進(jìn)程負(fù)責(zé)執(zhí)行),這樣主進(jìn)程在執(zhí)行回調(diào)函數(shù)時就省去了I/O的過程,直接拿到的是任務(wù)的結(jié)果。

            以上內(nèi)容為大家介紹了python進(jìn)程池,希望對大家有所幫助,如果想要了解更多Python相關(guān)知識,請關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。

            聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
            10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
            請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
            免費(fèi)領(lǐng)取
            今日已有369人領(lǐng)取成功
            劉同學(xué) 138****2860 剛剛成功領(lǐng)取
            王同學(xué) 131****2015 剛剛成功領(lǐng)取
            張同學(xué) 133****4652 剛剛成功領(lǐng)取
            李同學(xué) 135****8607 剛剛成功領(lǐng)取
            楊同學(xué) 132****5667 剛剛成功領(lǐng)取
            岳同學(xué) 134****6652 剛剛成功領(lǐng)取
            梁同學(xué) 157****2950 剛剛成功領(lǐng)取
            劉同學(xué) 189****1015 剛剛成功領(lǐng)取
            張同學(xué) 155****4678 剛剛成功領(lǐng)取
            鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
            董同學(xué) 138****2867 剛剛成功領(lǐng)取
            周同學(xué) 136****3602 剛剛成功領(lǐng)取
            相關(guān)推薦HOT