Go言語のWorker Poolパターンをマスター!効率的に並行処理を管理しよう
生徒
「先生、Goで複数のgoroutineを使うと便利ですが、数が増えすぎるとメモリやCPUが心配です。」
先生
「その通りです。そこでWorker Poolパターンを使うと、goroutineの数を制御しつつ効率的に並行処理ができます。」
生徒
「Worker Poolって具体的にはどういう仕組みですか?」
先生
「簡単に言うと、複数の作業員(Worker)がいて、仕事(Job)を順番に割り振る仕組みです。goroutineの数を一定に保ち、CPUやメモリを効率よく使えます。」
1. Worker Poolパターンの基本構造
Worker Poolは、仕事を送るjobsチャンネルと結果を受け取るresultsチャンネルを使います。複数のWorkerがjobsチャンネルから仕事を受け取り、処理結果をresultsチャンネルに送ります。
package main
import (
"fmt"
"sync"
"time"
)
func worker(id int, jobs <-chan int, results chan<- int, wg *sync.WaitGroup) {
defer wg.Done()
for j := range jobs {
fmt.Printf("Worker %d がジョブ %d を処理中\n", id, j)
time.Sleep(time.Second)
results <- j * 2
}
}
func main() {
jobs := make(chan int, 5)
results := make(chan int, 5)
var wg sync.WaitGroup
for w := 1; w <= 3; w++ {
wg.Add(1)
go worker(w, jobs, results, &wg)
}
for j := 1; j <= 5; j++ {
jobs <- j
}
close(jobs)
wg.Wait()
close(results)
for res := range results {
fmt.Println("結果:", res)
}
}
この例では3つのWorkerが存在し、5つのジョブを処理します。Worker Poolにより、goroutineの数を制御しながら並行処理を実現しています。
2. Worker Poolのメリット
- goroutineの数を制限できるため、CPUやメモリの消費を抑えられる
- ジョブの処理状況を簡単に管理できる
- 複数のWorkerで処理を分散し、全体の処理時間を短縮できる
- エラー処理やキャンセル処理を組み込みやすい
Worker Poolは大規模なデータ処理やWebサーバーのリクエスト処理など、多くの場面で応用できます。
3. Worker Poolのベストプラクティス
初心者でも安全にWorker Poolを使うためのポイントです。
- Workerの数はCPUコア数や処理の重さを考えて設定する
- channelを使うときはバッファ付きかどうかを検討する
sync.WaitGroupを使って全Workerの終了を待つ- ジョブ送信後は必ずchannelを
closeする - 結果チャンネルのcloseも忘れずに行い、安全に
rangeで受信する
これらのポイントを守ることで、Worker Poolを使った並行処理を安全かつ効率的に実装できます。
4. Worker Poolの応用例
Worker Poolは、例えばWebスクレイピングやAPIリクエスト、画像処理などで便利です。複数の処理を並列で実行しつつ、処理数を制限することでリソースの過剰消費を防ぎます。
例えば、10件の画像を3つのWorkerで同時に処理すると、CPUとメモリを安定させながら全ての画像を処理できます。Worker Poolは効率的で安全な並行処理の基本パターンです。
【超入門】ゼロから始めるGo言語プログラミング:最速で「動くアプリ」を作るマンツーマン指導
「プログラミングの仕組み」が根本からわかる。Go言語でバックエンド開発の第一歩を。
本講座を受講することで、単なる文法の暗記ではなく、「プログラムがコンピュータの中でどう動いているか」という本質的な理解につながります。シンプルながら強力なGo言語(Golang)を通じて、現代のバックエンドエンジニアに求められる基礎体力を最短距離で身につけます。
具体的な開発内容と環境
【つくるもの】
ターミナル(黒い画面)上で動作する「対話型計算プログラム」や、データを整理して表示する「ミニ・ツール」をゼロから作成します。自分の書いたコードが形になる感動を体験してください。
【開発環境】
プロの現場でシェアNo.1のVisual Studio Code (VS Code)を使用します。インストールから日本語化、Go言語用の拡張機能設定まで、現場基準の環境を一緒に構築します。
この60分で得られる3つの理解
「なぜ動くのか」という設定の仕組みを理解し、今後の独学で詰まらない土台を作ります。
データの種類やメモリの概念など、他言語にも通じるプログラミングの本質を学びます。
ただ動くだけでなく、誰が見ても分かりやすい「綺麗なコード」を書くための考え方を伝授します。
※本講座は、将来的にバックエンドエンジニアやクラウドインフラに興味がある未経験者のためのエントリー講座です。マンツーマン形式により、あなたの理解度に合わせて進行します。
初めてのGo言語を一緒に学びましょう!