首頁 >後端開發 >Golang >當 Goroutine 執行阻塞操作時,Go 調度器如何建立新的 M 和 P?

當 Goroutine 執行阻塞操作時,Go 調度器如何建立新的 M 和 P?

Patricia Arquette
Patricia Arquette原創
2024-10-30 02:18:28548瀏覽

How Does the Go Scheduler Create New M and P When Goroutines Perform Blocking Operations?

當Go Scheduler 在GMP 模型中建立新的M 和P

在Go 的GMP(Goroutine、Machine、Processor)模型中,調度器根據特定條件管理M(機器)和P(處理器)的創建。

M 創建

M 是為了響應特定事件而創建的,例如:

  • 阻塞操作:當goroutine 執行阻塞操作(例如,I/O、系統呼叫)時,與該goroutine 關聯的M 會被阻塞。為了繼續執行 Goroutine,調度器會建立一個新的 M。
  • 調度管道: 當儲存等待執行的 Goroutine 的全域 G 佇列中的 Goroutine 數量多於可用的 M 數量時,調度器會建立新的 M 來執行 goroutine。

P 建立

P 是在程式啟動時根據 GOMAXPROCS 環境變數建立的,該變數指定可用P的最大數量。預設值為系統上邏輯CPU的數量。

範例分析

在您的範例程式碼中,您有兩批goroutine執行資料庫操作。每個 goroutine 執行阻塞 I/O 操作。

  • 第一批: 調度程序將創建 8 M (因為您有 8 個虛擬核心)和 1 P 來運行第一批goroutine 的。每個M都會執行P的本地隊列中的一個goroutine。
  • 第二批:由於阻塞操作導致最初的M被阻塞,調度器將為剩餘的goroutine創建新的M在第二批中。 M 將與新的 P 相關聯,即使 P 的數量仍為 1。

因此,在您的情況下,調度程序將為第二批 goroutine 創建超過 8 M,因為操作被阻塞。 P 將根據 GOMAXPROCS 值限制為 1,但 M 將根據需要動態建立。

其他資源

進一步了解,請參考以下內容資源:

  • https://www.programmersought.com/article/ 795578​​885527/
  • https://blog.golang.org/go-goroutine-os-thread-and -CPU管理

以上是當 Goroutine 執行阻塞操作時,Go 調度器如何建立新的 M 和 P?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn