分類

展開全部 | 收合全部

分類

展開全部 | 收合全部

【Python 平行運算 #5】python pooling multiprocess – 用多核心來執行程式 sample code (內含範例程式碼)

前言

此部份可參考:【python】python thread multiprocess 比較總整理

在 python 中有 thread 與 multiprocess 兩種平行處理程式的方式,
兩者分別的特性為:

  • thread: 可直接使用全域變數 (global) 交換資訊
  • multiprocess: 需透過設定特定通道 (多核心執行的中央變數管理,另一篇文會提到) 才能拿到資訊

也因此會有不同的特性:

  • thread: 適合小任務、資訊共用的任務 (直接拿 global 資訊來用)
  • multiprocess: 適合大任務、資訊獨立的任務 (把相關資訊交由其他核心處理後,不太需要拿取新資訊)

而在時間上,python 的 thread 實作有使用 GIL (global interpreter lock) ,
這是為了保護程式取用資料衝突的機制 (一般而言,我們會自己建立 mutex 或 lock 來實現這一點),
但也因為內建此機制的原因,實際執行上會慢於 multiprocess。

(可以有一種想法是,當 python 的 thread 實現方式是建立在大量的 context switch上)

而 multiprocess 可以幫助我們更好的運用硬體的多核心資源,
也就是將電腦的能力發揮到更極限,達到更好的效果。
(一般執行程式只需要一個核心)

但要注意:送資料到別的核心需要時間
如果是簡單不需要太多時間的任務,
使用多核心運算的方式反而會在資料搬運上浪費更多時間。

小整理

功能threadmultiprocess
速度快 (受限於 GIL)更快
電腦資源使用極限更極限
資訊共用容易度相對容易複雜 (注意:送資料到別的核心需要時間)
適合任務小任務、資訊共用的任務大任務、資訊獨立的任務

thread 與 multiprocess 比較

threading 重點摘要

threading 是透過 context-switch 的方式實現
也就是說,我們是透過 CPU 的不斷切換 (context-switch),實現平行的功能。
當大量使用 threading 執行平行的功能時,反而會因為大量的 context-switch,
實現了程式平行的功能,但也因為大量的 context-switch ,使得程式執行速度更慢」。

multiprocessing 重點摘要

multiprocessing 在資料傳遞上,會因為需要將資料轉移至其他 CPU 上進行運算,
因此會需要考慮資料搬運的時間,
而多核心真正的實現「平行運算的功能」,當任務較為複雜時,效率一定比較好。

thread 與 multiprocess 比較圖

從下圖我們可以看到任務被完成的「概念」時間

  • main 1~4, main-end
  • 任務 A1, A2
  • 任務 B1, B2
  • 任務 C1, C2

請留意圖中粗線的部分:
* 在 multithread 中,
CPU context-switch 會額外消耗我們程式執行的時間,程式實際完成時間可能比一般的還要慢。

  • 在 multiprocess 中,
    我們需要將資料轉移至其他 CPU 會額外消耗我們程式執行的時間,如果任務過於簡單,效益可能不大。

雖然示意圖中明顯感覺較快,但前提是任務夠複雜
也就是說,「任務難度執行的時間 > 資料轉移至其他 CPU 的時間效益」,不然只會更慢。

Thread 基本使用,範例程式碼

import threading as td

def task(a, b):
    print('Task in the thread.')
    print(a, b)

if __name__=='__main__': # must put thread in the main
    t1 = td.Thread(target=job,args=(1,2))
    t1.start()
    t1.join()

multiprocess 實現,與取得結果

以下為範例 code,我們可在 task 做自己想做的事情,
最後透過 result.get() 拿回結果。

這裡我們做一個暫停 10 秒的實驗,
如果最後程式執行結束時間超過 40秒 (4核心),
表示這個程式並沒有多核心的執行。

sample code (範例程式碼)

import multiprocessing 
import time

def task(cpu_no):
    # do something
    print("cpu_no: ", cpu_no)
    time.sleep(10)
    result = cpu_no

    return result

def main():
    # multiprocessing.freeze_support()
    pool = multiprocessing.Pool()
    cpus = multiprocessing.cpu_count()
    print("cpu_count: ", cpus)
    results = []

    for i in range(0, cpus):
        result = pool.apply_async(task, args=(i,) )
        results.append(result)

    pool.close()
    pool.join()

    for result in results:
        print("result: ", result.get())


if __name__ == "__main__":
    main()


結果

我們可以看到,4核心的電腦,程式執行只花10秒左右,
能證明我們的程式確實有多核心執行。

⭐Python 基礎用法 相關文章整理⭐:
1.【Python】python list 清除, 移除內容元素 remove, pop, del, clear相關用法整理 sample code (內含範例程式碼)
2.【Python】寫模組 module、package 總整理 Importing files from different folder
3.【Python】python assert (斷言) 用法 sample code (內含範例程式碼)
4.【Python】python 一行 if else 語法 (one line if else) sample code (內含範例程式碼)
5.【Python】lambda 與 def function 使用方法與比較整理(內含範例程式碼)
6.【Python】python map 使用方法 與 其他寫法比較整理 (內含範例程式碼) sample code
7.【Python】python zip 使用方法 與 其他寫法比較整理 (內含範例程式碼) sample code
⭐Python 字串處理 相關文章整理⭐:
1.【Python】python print 變數的值 & 變數名稱 方法總整理
2.【Python】python string format str.format 總整理
⭐Python 檔案處理 相關文章整理⭐:
1.【Python】python 開關檔範例 與 程式模板 with open / file open sample code
2.【Python】取出檔案名稱 (含副檔名、不含副檔名) os path basename split 取出 檔名 路徑 不要副檔名 sample code
3.【Python】在 python 中利用 os.chmod 更改檔案的權限 chmod 777
4.【Python】利用 shutil 來複製檔案 shutil copy file
5.【Python】python 建立資料夾範例 mkdir os.makedirs() sample code
6.【Python】python 移除資料夾範例 rmdir shutil.rmtree() sample code
7.【Python】確認檔案是否存在 os.path.isfile / 確認資料夾是否存在 os.path.isdir sample code is folder / file exist
⭐Python 系統偵測 相關文章整理⭐:
1.【Python】python pyinotify sample code 偵測指定路徑底下的文件變化 (內有範例程式碼)
2.【Python】python 利用 argparse 使程式執行時可帶參數 (內附範例程式碼) sample code
⭐Python 平行運算 相關文章整理⭐:
1.【Python】threading – 建立多執行緒來執行程式 (內含範例程式碼) sample code
2.【Python】multiprocessing – 01 | 用多核心來執行程式 (內含範例程式碼) sample code
3.【Python】multiprocessing – 02 | pool, map, apply_async – 用多核心來執行程式並取得結果 (內含範例程式碼) sample code
4.【Python】python thread multiprocess 比較總整理
5.【Python】python pooling multiprocess – 用多核心來執行程式 sample code (內含範例程式碼)
⭐Python 測試程式 相關文章整理⭐:
1.【Python】python 測試程式 – 利用 doctest 測試 python testcase 的優雅寫法,適用於 leetcode (doctest in function,搭配 function 的用法)
2.【Leetcode】python – 利用 doctest 測試 leetcode python testcase 的優雅寫法 (doctest in class,搭配 class 的用法)
⭐Python Chatbot 相關文章整理⭐:
1.【Chatbot】(全圖文說明) LINE Developers bot 機器人註冊與設定
2.【Chatbot】(全圖文說明) ngrok 本地伺服器設定方法 – LINE bot local server
3.【Chatbot】Dialogflow API 串接 python 的方法 (內含範例程式碼)
4.【Chatbot】[講義分享] 手把手實作line機器人 (linebot API 運用)
⭐Python Google Colab (Colaboratory) 相關文章整理⭐:
1.【Colab】Python colab 上傳檔案的方法 (內含範例程式碼) upload files
2.【Colab】Python colab 連接 google 雲端硬碟取用資料 (內含範例程式碼) mount google drive
⭐Python 其他筆記 相關文章整理⭐:
1.【Python】anaconda 更新 (upgrade) python 3.8 版本筆記
2.【Sublime】Sublime 將縮排 “tab” 改成 4格空白 的方法 (圖文說明) sublime indent 4 spaces
3.【Sublime】Python 縮排小技巧 (很爛但實用) 快速將 tab 改成「4格空白」的方法
⭐【喜歡我的文章嗎? 歡迎幫我按讚~ 讓基金會請創作者喝一杯咖啡!
如果喜歡我的文章,請幫我在下方【按五下Like】 (Google, Facebook 免註冊),會由 「LikeCoin」 贊助作者鼓勵繼續創作,讀者們「只需幫忙按讚,完全不用出錢」哦!

likecoin-steps
Howard Weng
Howard Weng

我是 Howard Weng,很多人叫我嗡嗡。這個網站放了我的各種筆記。希望這些筆記也能順便幫助到有需要的人們!如果文章有幫助到你的話,歡迎幫我點讚哦!
另外,因為定位是「個人的隨手筆記」,有些文章內容「⚠️可能我理解有誤⚠️」或「?只寫到一半?」,如果有發現這樣的情況,歡迎在該文章的最下面留言提醒我!我會儘快修正或補上!感謝大家的建議與幫忙,讓網站能變得更好?

文章: 889

★留個言吧!內容有誤或想要補充也歡迎與我討論!