
深入理解python多進程編程
1、python多進程編程背景
python中的多進程最大的好處就是充分利用多核cpu的資源,不像python中的多線程,受制于GIL的限制,從而只能進行cpu分配,在python的多進程中,適合于所有的場合,基本上能用多線程的,那么基本上就能用多進程。
在進行多進程編程的時候,其實和多線程差不多,在多線程的包threading中,存在一個線程類Thread,在其中有三種方法來創(chuàng)建一個線程,啟動線程,其實在多進程編程中,存在一個進程類Process,也可以使用那集中方法來使用;在多線程中,內存中的數據是可以直接共享的,例如list等,但是在多進程中,內存數據是不能共享的,從而需要用單獨的數據結構來處理共享的數據;在多線程中,數據共享,要保證數據的正確性,從而必須要有所,但是在多進程中,鎖的考慮應該很少,因為進程是不共享內存信息的,進程之間的交互數據必須要通過特殊的數據結構,在多進程中,主要的內容如下圖:
2、多進程的類Process
多進程的類Process和多線程的類Thread差不多的方法,兩者的接口基本相同,具體看以下的代碼:
在上面例子中可以看到,多進程和多線程的API接口是一樣一樣的,顯示創(chuàng)建進程,然后進行start開始運行,然后join等待進程結束。
在需要執(zhí)行的函數中,打印出了進程的id和pid,從而可以看到父進程和子進程的id號,在linu中,進程主要是使用fork出來的,在創(chuàng)建進程的時候可以查詢到父進程和子進程的id號,而在多線程中是無法找到線程的id,執(zhí)行效果如下:
在操作系統中查詢的id的時候,最好用pstree,清晰:
├─sshd(1508)─┬─sshd(2259)───bash(2261)───python(7520)─┬─python(7521) │ │ ├─python(7522) │ │ ├─python(7523) │ │ ├─python(7524) │ │ ├─python(7525) │ │ ├─python(7526) │ │ ├─python(7527) │ │ ├─python(7528) │ │ ├─python(7529) │ │ ├─python(7530) │ │ ├─python(7531) │ │ └─python(7532)
在進行運行的時候,可以看到,如果沒有join語句,那么主進程是不會等待子進程結束的,是一直會執(zhí)行下去,然后再等待子進程的執(zhí)行。
在多進程的時候,說,我怎么得到多進程的返回值呢?然后寫了下面的代碼:
嘗試從結果中返回值,從而在主進程中得到子進程的返回值,然而,,,并沒有結果,后來一想,在進程中,進程之間是不共享內存的 ,那么使用list來存放數據顯然是不可行的,進程之間的交互必須依賴于特殊的數據結構,從而以上的代碼僅僅是執(zhí)行進程,不能得到進程的返回值,但是以上代碼修改為線程,那么是可以得到返回值的。
3、進程間的交互Queue
進程間交互的時候,首先就可以使用在多線程里面一樣的Queue結構,但是在多進程中,必須使用multiprocessing里的Queue,代碼如下:
其實這個是上面例子的改進,在其中,并沒有使用什么其他的代碼,主要就是使用Queue來保存數據,從而可以達到進程間交換數據的目的。
在進行使用Queue的時候,其實用的是socket,感覺,因為在其中使用的還是發(fā)送send,然后是接收recv。
在進行數據交互的時候,其實是父進程和所有的子進程進行數據交互,所有的子進程之間基本是沒有交互的,除非,但是,也是可以的,例如,每個進程去Queue中取數據,但是這個時候應該是要考慮鎖,不然可能會造成數據混亂。
4、 進程之間交互Pipe
在進程之間交互數據的時候還可以使用Pipe,代碼如下:
在以上代碼中,主要是使用Pipe中返回的兩個socket來進行傳輸和接收數據,在父進程中,使用的是parent_conn,在子進程中使用的是child_conn,從而子進程發(fā)送數據的方法send,而在父進程中進行接收方法recv
最好的地方在于,明確的知道收發(fā)的次數,但是如果某個出現異常,那么估計pipe不能使用了。
5、進程池pool
其實在使用多進程的時候,感覺使用pool是最方便的,在多線程中是不存在pool的。
在使用pool的時候,可以限制每次的進程數,也就是剩余的進程是在排隊,而只有在設定的數量的進程在運行,在默認的情況下,進程是cpu的個數,也就是根據multiprocessing.cpu_count()得出的結果。
在poo中,有兩個方法,一個是map一個是imap,其實這兩方法超級方便,在執(zhí)行結束之后,可以得到每個進程的返回結果,但是缺點就是每次的時候,只能有一個參數,也就是在執(zhí)行的函數中,最多是只有一個參數的,否則,需要使用組合參數的方法,代碼如下所示:
在使用map的時候,直接返回的一個是一個list,從而這個list也就是函數執(zhí)行的結果,而在imap中,返回的是一個由結果組成的迭代器,如果需要使用多個參數的話,那么估計需要*args,從而使用參數args。
在使用apply.async的時候,可以直接使用多個參數,如下所示:
在進行得到各個結果的時候,注意使用了一個list來進行append,要不然在得到結果get的時候會阻塞進程,從而將多進程編程了單進程,從而使用了一個list來存放相關的結果,在進行得到get數據的時候,可以設置超時時間,也就是get(timeout=5),這種設置。
總結:
在進行多進程編程的時候,注意進程之間的交互,在執(zhí)行函數之后,如何得到執(zhí)行函數的結果,可以使用特殊的數據結構,例如Queue或者Pipe或者其他,在使用pool的時候,可以直接得到結果,map和imap都是直接得到一個list和可迭代對象,而apply_async得到的結果需要用一個list裝起來,然后得到每個結果。
數據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
SQL Server 中 CONVERT 函數的日期轉換:從基礎用法到實戰(zhàn)優(yōu)化 在 SQL Server 的數據處理中,日期格式轉換是高頻需求 —— 無論 ...
2025-09-18MySQL 大表拆分與關聯查詢效率:打破 “拆分必慢” 的認知誤區(qū) 在 MySQL 數據庫管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數據分析師:表結構數據 “獲取 - 加工 - 使用” 全流程的賦能者 表結構數據(如數據庫表、Excel 表、CSV 文件)是企業(yè)數字 ...
2025-09-18DSGE 模型中的 Et:理性預期算子的內涵、作用與應用解析 動態(tài)隨機一般均衡(Dynamic Stochastic General Equilibrium, DSGE)模 ...
2025-09-17Python 提取 TIF 中地名的完整指南 一、先明確:TIF 中的地名有哪兩種存在形式? 在開始提取前,需先判斷 TIF 文件的類型 —— ...
2025-09-17CDA 數據分析師:解鎖表結構數據特征價值的專業(yè)核心 表結構數據(以 “行 - 列” 規(guī)范存儲的結構化數據,如數據庫表、Excel 表、 ...
2025-09-17Excel 導入數據含缺失值?詳解 dropna 函數的功能與實戰(zhàn)應用 在用 Python(如 pandas 庫)處理 Excel 數據時,“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗與 t 檢驗:差異、適用場景與實踐應用 在數據分析與統計學領域,假設檢驗是驗證研究假設、判斷數據差異是否 “ ...
2025-09-16CDA 數據分析師:掌控表格結構數據全功能周期的專業(yè)操盤手 表格結構數據(以 “行 - 列” 存儲的結構化數據,如 Excel 表、數據 ...
2025-09-16MySQL 執(zhí)行計劃中 rows 數量的準確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調優(yōu)中,EXPLAIN執(zhí)行計劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對象的 text 與 content:區(qū)別、場景與實踐指南 在 Python 進行 HTTP 網絡請求開發(fā)時(如使用requests ...
2025-09-15CDA 數據分析師:激活表格結構數據價值的核心操盤手 表格結構數據(如 Excel 表格、數據庫表)是企業(yè)最基礎、最核心的數據形態(tài) ...
2025-09-15Python HTTP 請求工具對比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請求(如接口調用、數據爬取 ...
2025-09-12解決 pd.read_csv 讀取長浮點數據的科學計數法問題 為幫助 Python 數據從業(yè)者解決pd.read_csv讀取長浮點數據時的科學計數法問題 ...
2025-09-12CDA 數據分析師:業(yè)務數據分析步驟的落地者與價值優(yōu)化者 業(yè)務數據分析是企業(yè)解決日常運營問題、提升執(zhí)行效率的核心手段,其價值 ...
2025-09-12用 SQL 驗證業(yè)務邏輯:從規(guī)則拆解到數據把關的實戰(zhàn)指南 在業(yè)務系統落地過程中,“業(yè)務邏輯” 是連接 “需求設計” 與 “用戶體驗 ...
2025-09-11塔吉特百貨孕婦營銷案例:數據驅動下的精準零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當下,精準營銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數據分析師與戰(zhàn)略 / 業(yè)務數據分析:概念辨析與協同價值 在數據驅動決策的體系中,“戰(zhàn)略數據分析”“業(yè)務數據分析” 是企業(yè) ...
2025-09-11Excel 數據聚類分析:從操作實踐到業(yè)務價值挖掘 在數據分析場景中,聚類分析作為 “無監(jiān)督分組” 的核心工具,能從雜亂數據中挖 ...
2025-09-10統計模型的核心目的:從數據解讀到決策支撐的價值導向 統計模型作為數據分析的核心工具,并非簡單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10