検索
ホームページバックエンド開発GolangGo 同時実行性の習得: 高性能アプリケーションに不可欠なパターン

Mastering Go Concurrency: Essential Patterns for High-Performance Applications

Go で効率的でスケーラブルなアプリケーションを構築するには、同時実行パターンをマスターすることが重要です。 Go は、軽量のゴルーチンと強力なチャネルを備えており、同時プログラミングに理想的な環境を提供します。ここでは、Goroutine プール、ワーカー キュー、ファンアウト/ファンイン パターンなどの最も効果的な同時実行パターンのいくつかを、ベスト プラクティスと避けるべき一般的な落とし穴とともに詳しく掘り下げます。

ゴルーチン プール

Go で同時実行性を管理する最も効率的な方法の 1 つは、Goroutine プールを使用することです。 goroutine プールは、常にアクティブに実行されている goroutine の数を制御します。これは、メモリや CPU 時間などのシステム リソースの節約に役立ちます。このアプローチは、システムに負荷をかけずに多数のタスクを同時に処理する必要がある場合に特に役立ちます。

Goroutine プールを実装するには、プールを形成する固定数の Goroutine を作成することから始めます。これらのゴルーチンはタスクを実行するために再利用され、ゴルーチンの継続的な作成と破棄に伴うオーバーヘッドが削減されます。以下は、Goroutine プールを実装する方法の簡単な例です:

package main

import (
    "fmt"
    "sync"
    "time"
)

type Job func()

func worker(id int, jobs 



<h3>
  
  
  プールの適切なサイズ設定
</h3>

<p>Goroutine プールの最適なサイズを決定することが重要です。ゴルーチンが少なすぎると CPU が十分に活用されない可能性があり、多すぎると競合や高いオーバーヘッドが発生する可能性があります。ワークロードとシステム容量に基づいてプール サイズのバランスを取る必要があります。 pprof などのツールを使用してパフォーマンスを監視すると、必要に応じてプール サイズを調整できます。</p>

<h3>
  
  
  ワーカーキューの設計と管理
</h3>

<p>ワーカーキューは本質的に、プール内のゴルーチン間のタスクの分散を管理するチャネルです。このキューを効果的に管理することで、タスクが均等に分散され、一部のゴルーチンが過負荷になり、他のゴルーチンがアイドル状態になることを防ぎます。</p>

<p>ワーカー キューを設計する方法は次のとおりです。<br>
</p>

<pre class="brush:php;toolbar:false">package main

import (
    "fmt"
    "sync"
)

type Worker struct {
    id       int
    jobQueue chan Job
    wg       *sync.WaitGroup
}

func NewWorker(id int, jobQueue chan Job, wg *sync.WaitGroup) *Worker {
    return &Worker{id: id, jobQueue: jobQueue, wg: wg}
}

func (w *Worker) Start() {
    defer w.wg.Done()
    for job := range w.jobQueue {
        fmt.Printf("Worker %d starting job\n", w.id)
        job()
        fmt.Printf("Worker %d finished job\n", w.id)
    }
}

func main() {
    jobQueue := make(chan Job, 100)
    var wg sync.WaitGroup

    // Start 5 workers.
    for i := 1; i 



<h3>
  
  
  ファンアウト/ファンイン パターン
</h3>

<p>ファンアウト/ファンイン パターンは、同時タスクを並列化および調整するための強力な手法です。このパターンは、ファンアウトとファンインという 2 つの主要な段階で構成されます。</p>

<h4>
  
  
  ファンアウト
</h4>

<p>ファンアウト段階では、単一のタスクが、同時に実行できる複数の小さなサブタスクに分割されます。各サブタスクは個別の goroutine に割り当てられ、並列処理が可能になります。</p>

<h4>
  
  
  ファンイン
</h4>

<p>ファンイン ステージでは、同時に実行されているすべてのサブタスクからの結果または出力が収集され、1 つの結果に結合されます。このステージでは、すべてのサブタスクが完了するのを待ち、その結果を集計します。</p><p>ここでは、ファンアウト/ファンイン パターンを実装して数値を同時に 2 倍にする方法の例を示します。<br>
</p>

<pre class="brush:php;toolbar:false">package main

import (
    "fmt"
    "sync"
    "time"
)

type Job func()

func worker(id int, jobs 



<h3>
  
  
  同期プリミティブ
</h3>

<p>WaitGroup、Mutex、チャネルなどの同期プリミティブは、ゴルーチンを調整し、同時実行プログラムが正しく動作することを保証するために不可欠です。</p>

<h4>
  
  
  待機グループ
</h4>

<p>WaitGroup は、ゴルーチンのコレクションが完了するのを待つために使用されます。使用方法は次のとおりです:<br>
</p>

<pre class="brush:php;toolbar:false">package main

import (
    "fmt"
    "sync"
)

type Worker struct {
    id       int
    jobQueue chan Job
    wg       *sync.WaitGroup
}

func NewWorker(id int, jobQueue chan Job, wg *sync.WaitGroup) *Worker {
    return &Worker{id: id, jobQueue: jobQueue, wg: wg}
}

func (w *Worker) Start() {
    defer w.wg.Done()
    for job := range w.jobQueue {
        fmt.Printf("Worker %d starting job\n", w.id)
        job()
        fmt.Printf("Worker %d finished job\n", w.id)
    }
}

func main() {
    jobQueue := make(chan Job, 100)
    var wg sync.WaitGroup

    // Start 5 workers.
    for i := 1; i 



<h4>
  
  
  ミューテックス
</h4>

<p>ミューテックスは、共有リソースを同時アクセスから保護するために使用されます。以下に例を示します:<br>
</p>

<pre class="brush:php;toolbar:false">package main

import (
    "fmt"
    "sync"
)

func doubleNumber(num int) int {
    return num * 2
}

func main() {
    numbers := []int{1, 2, 3, 4, 5}
    jobs := make(chan int)
    results := make(chan int)

    var wg sync.WaitGroup

    // Start 5 worker goroutines.
    for i := 0; i 



<h3>
  
  
  正常なシャットダウンの処理
</h3>

<p>並行システムでは、プログラムが終了する前に進行中のすべてのタスクが確実に完了するように、正常なシャットダウンが重要です。終了シグナルを使用して正常なシャットダウンを処理する方法は次のとおりです:<br>
</p>

<pre class="brush:php;toolbar:false">package main

import (
    "fmt"
    "sync"
)

func main() {
    var wg sync.WaitGroup
    for i := 0; i 



<h3>
  
  
  同時実行コードのベンチマークと最適化
</h3>

<p>同時実行コードのパフォーマンスを理解するには、ベンチマークが不可欠です。 Go は、ベンチマーク用のツールを含む組み込みのテスト パッケージを提供します。</p>

<p>これは、単純な同時関数のベンチマークを実行する方法の例です:<br>
</p>

<pre class="brush:php;toolbar:false">package main

import (
    "fmt"
    "sync"
)

type Counter struct {
    mu    sync.Mutex
    count int
}

func (c *Counter) Increment() {
    c.mu.Lock()
    c.count++
    c.mu.Unlock()
}

func (c *Counter) GetCount() int {
    c.mu.Lock()
    defer c.mu.Unlock()
    return c.count
}

func main() {
    counter := &Counter{}
    var wg sync.WaitGroup

    for i := 0; i 



<p>ベンチマークを実行するには、-bench フラグを指定して go test コマンドを使用できます。<br>
</p>

<pre class="brush:php;toolbar:false">package main

import (
    "fmt"
    "sync"
    "time"
)

func worker(id int, quit 



<h3>
  
  
  エラー処理戦略
</h3>

<p>ゴルーチンの非同期的な性質により、同時実行プログラムでのエラー処理は困難になる場合があります。エラーを効果的に処理するための戦略をいくつか示します:</p>

<h4>
  
  
  チャネルの使用
</h4>

<p>チャネルを使用して、ゴルーチンからメインのゴルーチンにエラーを伝播できます。<br>
</p>

<pre class="brush:php;toolbar:false">package main

import (
    "testing"
    "time"
)

func concurrentWork() {
    var wg sync.WaitGroup
    for i := 0; i 



<h4>
  
  
  コンテキストの使用
</h4>

<p>コンテキスト パッケージは、操作をキャンセルし、ゴルーチン間でエラーを伝播する方法を提供します。<br>
</p>

<pre class="brush:php;toolbar:false">go test -bench=. -benchmem -benchtime=10s

結論として、堅牢でスケーラブルで効率的なアプリケーションを構築するには、Go の同時実行パターンをマスターすることが不可欠です。 goroutine プール、ワーカー キュー、ファンアウト/ファンイン パターンを理解して実装し、適切な同期プリミティブを使用することで、同時実行システムのパフォーマンスと信頼性を大幅に向上させることができます。常にエラーを適切に処理し、コードのベンチマークを行って最適なパフォーマンスを確保することを忘れないでください。これらの戦略により、Go の同時実行機能の可能性を最大限に活用して、高パフォーマンスのアプリケーションを構築できます。


私たちの作品

私たちの作品をぜひチェックしてください:

インベスターセントラル | スマートな暮らし | エポックとエコー | 不可解な謎 | ヒンドゥーヴァ | エリート開発者 | JS スクール


私たちは中程度です

Tech Koala Insights | エポックズ&エコーズワールド | インベスター・セントラル・メディア | 不可解な謎 中 | 科学とエポックミディアム | 現代ヒンドゥーヴァ

以上がGo 同時実行性の習得: 高性能アプリケーションに不可欠なパターンの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

GolangisidealforBuildingsCalables Systemsduetoitsefficiency andConcurrency、Whilepythonexcelsinquickscriptinganddataanalysisduetoitssimplicityand vastecosystem.golang'ssignencouragesclean、readisinediteNeditinesinedinediseNabletinedinedinedisedisedioncourase

Golang and C:Concurrency vs. Raw SpeedGolang and C:Concurrency vs. Raw SpeedApr 21, 2025 am 12:16 AM

Golangは並行性がCよりも優れていますが、Cは生の速度ではGolangよりも優れています。 1)Golangは、GoroutineとChannelを通じて効率的な並行性を達成します。これは、多数の同時タスクの処理に適しています。 2)Cコンパイラの最適化と標準ライブラリを介して、極端な最適化を必要とするアプリケーションに適したハードウェアに近い高性能を提供します。

なぜゴランを使うのですか?説明された利点と利点が説明されていますなぜゴランを使うのですか?説明された利点と利点が説明されていますApr 21, 2025 am 12:15 AM

Golangを選択する理由には、1)高い並行性パフォーマンス、2)静的タイプシステム、3)ガベージ収集メカニズム、4)豊富な標準ライブラリとエコシステムは、効率的で信頼できるソフトウェアを開発するための理想的な選択肢となります。

Golang vs. C:パフォーマンスと速度の比較Golang vs. C:パフォーマンスと速度の比較Apr 21, 2025 am 12:13 AM

Golangは迅速な発展と同時シナリオに適しており、Cは極端なパフォーマンスと低レベルの制御が必要なシナリオに適しています。 1)Golangは、ごみ収集と並行機関のメカニズムを通じてパフォーマンスを向上させ、高配列Webサービス開発に適しています。 2)Cは、手動のメモリ管理とコンパイラの最適化を通じて究極のパフォーマンスを実現し、埋め込みシステム開発に適しています。

GolangはCよりも速いですか?制限の調査GolangはCよりも速いですか?制限の調査Apr 20, 2025 am 12:19 AM

Golangは、コンピレーション時間と同時処理においてより良いパフォーマンスを発揮しますが、Cはランニング速度とメモリ管理においてより多くの利点があります。 1.Golangの編集速度は速く、迅速な発展に適しています。 2.Cは速く実行され、パフォーマンスクリティカルなアプリケーションに適しています。 3. Golangは、同時処理においてシンプルで効率的で、同時プログラミングに適しています。 4.Cマニュアルメモリ管理により、パフォーマンスが高くなりますが、開発の複雑さが向上します。

Golang:WebサービスからシステムプログラミングまでGolang:WebサービスからシステムプログラミングまでApr 20, 2025 am 12:18 AM

WebサービスとシステムプログラミングへのGolangのアプリケーションは、主にそのシンプルさ、効率性、並行性に反映されています。 1)Webサービスでは、Golangは、強力なHTTPライブラリと同時処理機能を介して、高性能WebアプリケーションとAPIの作成をサポートしています。 2)システムプログラミングでは、Golangはハードウェアに近い機能とC言語との互換性を使用して、オペレーティングシステムの開発と組み込みシステムに適しています。

Golang vs. C:ベンチマークと現実世界のパフォーマンスGolang vs. C:ベンチマークと現実世界のパフォーマンスApr 20, 2025 am 12:18 AM

GolangとCには、パフォーマンスの比較に独自の利点と欠点があります。1。ゴーランは、高い並行性と迅速な発展に適していますが、ごみ収集はパフォーマンスに影響を与える可能性があります。 2.Cは、パフォーマンスとハードウェア制御を高くしますが、開発の複雑さが高くなります。選択を行うときは、プロジェクトの要件とチームのスキルを包括的な方法で考慮する必要があります。

Golang vs. Python:比較分析Golang vs. Python:比較分析Apr 20, 2025 am 12:17 AM

Golangは、高性能および同時プログラミングシナリオに適していますが、Pythonは迅速な開発とデータ処理に適しています。 1.Golangは、シンプルさと効率性を強調し、バックエンドサービスとマイクロサービスに適しています。 2。Pythonは、データサイエンスと機械学習に適した簡潔な構文とリッチライブラリで知られています。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。