91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

      手機站
      千鋒教育

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

      千鋒教育

      掃一掃進入千鋒手機站

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

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

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

      python 進程池

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

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

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

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

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

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

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

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

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

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

      參數(shù)介紹:

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

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

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

      主要方法:

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

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

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

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

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

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

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

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

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

      應(yīng)用

      同步調(diào)用applay

      異步調(diào)用apply_async

      apply_async與apply詳解

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

      server端

      客戶端

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

      回掉函數(shù):

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

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

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

      聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
      10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
      請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
      免費領(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