ホームページ バックエンド開発 Golang Go ルーチンがブロック操作を実行するときに、Go スケジューラはどのようにして新しい M と P を作成しますか?

Go ルーチンがブロック操作を実行するときに、Go スケジューラはどのようにして新しい M と P を作成しますか?

Oct 30, 2024 am 02:18 AM

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

Go スケジューラが GMP モデルに新しい M と P を作成するとき

Go の GMP (Goroutine、Machine、Processor) モデルでは、スケジューラ特定の条件に基づいて M (マシン) と P (プロセッサ) の作成を管理します。

M 作成

M は、次のような特定のイベントに応答して作成されます。

  • ブロック操作: ゴルーチンがブロック操作 (I/O、syscall など) を実行すると、そのゴルーチンに関連付けられた M がブロックされます。ゴルーチンの実行を続けるために、スケジューラは新しい M を作成します。
  • パイプラインのスケジュール: 実行を待機しているゴルーチンを格納するグローバル G キューに、使用可能な M の数より多くのゴ​​ルーチンがある場合

P Creation

P は、GOMAXPROCS 環境変数に基づいてプログラムの起動時に作成されます。使用可能な P の最大数。デフォルト値は、システム上の論理 CPU の数です。

分析例

サンプル コードには、ゴルーチンの 2 つのバッチがあります。データベース操作を実行しています。各ゴルーチンはブロッキング I/O 操作を実行します。

  • 最初のバッチ: スケジューラは、最初のバッチを実行するために 8 M (仮想コアが 8 つあるため) と 1 P を作成します。ゴルーチンの。各 M は P のローカル キューからゴルーチンを実行します。
  • 第 2 バッチ: ブロック操作により最初の M がブロックされるため、スケジューラーは残りのゴルーチンに対して新しい M を作成します。 2番目のバッチで。 P の数が 1 のままであっても、M は新しい P に関連付けられます。

したがって、あなたの場合、スケジューラはゴルーチンの 2 番目のバッチに 8 M を超える M を作成します。操作がブロックされています。 P は GOMAXPROCS 値に基づいて 1 に制限されますが、M は必要に応じて動的に作成されます。

追加リソース

さらに理解するには、次を参照してください。リソース:

  • https://www.programmersought.com/article/795578​​85527/
  • https://blog.golang.org/go-goroutine-os-thread-and -cpu-management

以上がGo ルーチンがブロック操作を実行するときに、Go スケジューラはどのようにして新しい M と P を作成しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Stock Market GPT

Stock Market GPT

AIを活用した投資調査により賢明な意思決定を実現

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ホットトピック

Golangで使用される空のstruct struct {}は何ですか Golangで使用される空のstruct struct {}は何ですか Sep 18, 2025 am 05:47 AM

struct {}はgoのフィールドレス構造であり、ゼロバイトを占有し、データが不要なシナリオでよく使用されます。 Goroutine同期など、チャネル内の信号として使用されます。 2。効率的なメモリの重要な存在チェックを実現するために、値の種類のコレクションとして使用されます。 3.依存関係の注入または組織機能に適した定義可能なステートレスメソッドレシーバー。このタイプは、制御フローと明確な意図を表現するために広く使用されています。

Golangでファイルをどのように読み取り、書き込みますか? Golangでファイルをどのように読み取り、書き込みますか? Sep 21, 2025 am 01:59 AM

Goprovidessimpleandefficientfilehandlingusingtheosandbufiopackages.Toreadasmallfileentirely,useos.ReadFile,whichloadsthecontentintomemorysafelyandautomaticallymanagesfileoperations.Forlargefilesorincrementalprocessing,bufio.Scannerallowsline-by-liner

GOプログラムで外部エディターを開始し、それが完了するのを待ちます GOプログラムで外部エディターを開始し、それが完了するのを待ちます Sep 16, 2025 pm 12:21 PM

この記事では、GOプログラムで外部エディター(VIMやNanoなど)を開始し、プログラムが実行され続ける前にユーザーがエディターを閉じるのを待つ方法について説明します。 cmd.stdin、cmd.stdout、およびcmd.stderrを設定することにより、編集者は端末と対話して、起動の障害の問題を解決できます。同時に、完全なコードの例が表示され、開発者がこの機能をスムーズに実装するのに役立つ予防策が提供されます。

Go WebSocketEOFエラー:接続をアクティブに保ちます Go WebSocketEOFエラー:接続をアクティブに保ちます Sep 16, 2025 pm 12:15 PM

この記事は、GOを使用してWebSocketを開発するときに遭遇するEOF(ファイルの終了)エラーを解決することを目的としています。通常、このエラーは、サーバーがクライアントメッセージを受信し、接続が予期せず閉じられている場合に発生し、その後のメッセージを正常に配信できません。この記事では、問題の原因を分析し、コードの例を提供し、対応するソリューションを提供して、開発者が安定した信頼できるWebSocketアプリケーションを構築できるようにします。

Golang Webサーバーのコンテキストのミドルウェアは何ですか? Golang Webサーバーのコンテキストのミドルウェアは何ですか? Sep 16, 2025 am 02:16 AM

ミドルウェアワーシングウェブシュアレーバーは、interceptttprequestSeyreatheyreachtheTheTheHandlerを使用して、カットカッティングの機能性を有効にします

Golangのファイルから構成を読み取る方法 Golangのファイルから構成を読み取る方法 Sep 18, 2025 am 05:26 AM

標準ライブラリのエンコード/JSONパッケージを使用して、JSON構成ファイルを読み取ります。 2。GOPKG.in/Yaml.v3ライブラリを使用して、YAML形式の構成を読み取ります。 3. os.getenvまたはgodotenvライブラリを使用して、ファイル構成を上書きします。 4. Viperライブラリを使用して、マルチフォーマット構成、環境変数、自動リロードなどの高度な機能をサポートします。タイプの安全性を確保し、ファイルと解析エラーを適切に処理し、構造タグマッピングフィールドを正しく使用し、ハードコーディングパスを避け、環境変数または生産環境での安全な構成ストレージを使用することをお勧めするために、構造を定義する必要があります。単純なJSONから始めて、要件が複雑な場合にViperに移行できます。

Golangアプリケーションの優雅なシャットダウンをどのように処理しますか? Golangアプリケーションの優雅なシャットダウンをどのように処理しますか? Sep 21, 2025 am 02:30 AM

GracefulshutdownsingoApplicationSaresentialForreliability、retureved vedeved bytevedeved byteved interceptingsignalsigintandsig themusinging theos/signalpackagetoinitiateShutdownprocedures、その後、spapppppstpstp.server’sshutdodd()方法

CGOとは何ですか、そしてGolangでいつ使用するか CGOとは何ですか、そしてGolangでいつ使用するか Sep 21, 2025 am 02:55 AM

cgoenablesgotocallcode、clibraries likeopenssl、accesstolow-levelsystemapis、およびperformanceptimizationを使用することを可能にします

See all articles