カテゴリ: Go言語 更新日: 2025/12/30

Go言語の並行処理設計パターン集!パイプライン・ファンアウト徹底解説

Go言語の並行処理設計パターン集(パイプライン・ファンアウトなど)
Go言語の並行処理設計パターン集(パイプライン・ファンアウトなど)

先生と生徒の会話形式で理解しよう

生徒

「Goで複数の処理を同時に動かすとき、どうやって設計すればいいですか?」

先生

「Goでは、goroutineとchannelを組み合わせて効率的に処理を設計する方法があります。代表的なのはパイプラインとファンアウトのパターンです。」

生徒

「パイプラインとファンアウトって何ですか?」

先生

「簡単に言うと、パイプラインは処理を順番につなげる流れ、ファンアウトは同じ処理を複数のgoroutineで分担するやり方です。」

1. パイプラインパターンとは?

1. パイプラインパターンとは?
1. パイプラインパターンとは?

パイプラインは、処理を段階ごとに分けて、それぞれを独立したgoroutineで実行し、channelでデータを渡す設計パターンです。これにより、大きな処理を小さく分けて効率よく処理できます。

例えば、データを読み込む、加工する、出力するという三段階の処理を考えます。各段階を別のgoroutineで実行し、channelでデータを渡すことで、処理全体の速度を向上させられます。

2. パイプラインのサンプルコード

2. パイプラインのサンプルコード
2. パイプラインのサンプルコード

package main

import "fmt"

func main() {
    nums := make(chan int)
    squares := make(chan int)

    // 数字を生成するgoroutine
    go func() {
        for i := 1; i <= 5; i++ {
            nums <- i
        }
        close(nums)
    }()

    // 数字を二乗するgoroutine
    go func() {
        for n := range nums {
            squares <- n * n
        }
        close(squares)
    }()

    // 結果を表示
    for sq := range squares {
        fmt.Println(sq)
    }
}

この例では、数字を生成するgoroutineと二乗するgoroutineがchannelでデータを渡しています。これがパイプラインの基本的な考え方です。

3. ファンアウトパターンとは?

3. ファンアウトパターンとは?
3. ファンアウトパターンとは?

ファンアウトは、同じ入力を複数のgoroutineで処理して負荷を分散する設計パターンです。大量の処理を効率よくさばくときに有効です。

例えば、ウェブから複数のデータを取得して処理する場合、goroutineを複数立ち上げて同時に処理することで、全体の処理時間を短縮できます。

4. ファンアウトのサンプルコード

4. ファンアウトのサンプルコード
4. ファンアウトのサンプルコード

package main

import (
    "fmt"
    "sync"
)

func worker(id int, jobs <-chan int, results chan<- int, wg *sync.WaitGroup) {
    defer wg.Done()
    for j := range jobs {
        results <- j * 2
    }
}

func main() {
    jobs := make(chan int, 5)
    results := make(chan int, 5)
    var wg sync.WaitGroup

    // ワーカーを3つ立ち上げる
    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)

    // ワーカーの終了を待つ
    go func() {
        wg.Wait()
        close(results)
    }()

    for res := range results {
        fmt.Println(res)
    }
}

この例では、3つのワーカーgoroutineがjobsチャネルからデータを受け取り、処理結果をresultsチャネルに送っています。これがファンアウトの基本形です。

Go言語を基礎からスッキリ学びたい人や、 文法だけでなく「実用的な使い方」まで押さえたい人には、 定番の入門書がこちらです。

基礎からわかるGo言語をAmazonで見る

※ Amazon広告リンク

5. パイプラインとファンアウトを組み合わせる

5. パイプラインとファンアウトを組み合わせる
5. パイプラインとファンアウトを組み合わせる

実際のシステムでは、パイプラインとファンアウトを組み合わせることで、高速かつ効率的な並行処理が可能です。パイプラインで段階的に処理しつつ、各段階でファンアウトを使い処理を分散させることで、大量データの処理もスムーズになります。

ポイントは、goroutineを無制限に増やさず、channelで適切にデータを制御することです。バッファ付きchannelを利用すると、処理が詰まるのを防ぎ、安定した並行処理ができます。

関連セミナーのご案内

【超入門】ゼロから始めるGo言語プログラミング:最速で「動くアプリ」を作るマンツーマン指導

「プログラミングの仕組み」が根本からわかる。Go言語でバックエンド開発の第一歩を。

本講座を受講することで、単なる文法の暗記ではなく、「プログラムがコンピュータの中でどう動いているか」という本質的な理解につながります。シンプルながら強力なGo言語(Golang)を通じて、現代のバックエンドエンジニアに求められる基礎体力を最短距離で身につけます。

具体的な開発内容と環境

【つくるもの】
ターミナル(黒い画面)上で動作する「対話型計算プログラム」や、データを整理して表示する「ミニ・ツール」をゼロから作成します。自分の書いたコードが形になる感動を体験してください。

【開発環境】
プロの現場でシェアNo.1のVisual Studio Code (VS Code)を使用します。インストールから日本語化、Go言語用の拡張機能設定まで、現場基準の環境を一緒に構築します。

この60分で得られる3つの理解

1. 環境構築の完全な理解

「なぜ動くのか」という設定の仕組みを理解し、今後の独学で詰まらない土台を作ります。

2. Go言語の基本構造(変数・型)

データの種類やメモリの概念など、他言語にも通じるプログラミングの本質を学びます。

3. 読みやすいコードの書き方

ただ動くだけでなく、誰が見ても分かりやすい「綺麗なコード」を書くための考え方を伝授します。

※本講座は、将来的にバックエンドエンジニアクラウドインフラに興味がある未経験者のためのエントリー講座です。マンツーマン形式により、あなたの理解度に合わせて進行します。

セミナー画像

初めてのGo言語を一緒に学びましょう!

カテゴリの一覧へ
新着記事
New1
Swift
Swiftのnilとは?Optionalとの関係や初期化について初心者向けにやさしく解説!
New2
Go言語
Go言語のinit関数の役割と使い方!プログラム起動時の初期化処理
New3
Go言語
Go言語のマップの順序保証がない理由と扱い方の工夫をやさしく解説!初心者でもわかる基本知識
New4
Kotlin
Kotlinのforループの基本!範囲・配列・コレクションの繰り返し処理
人気記事
No.1
Java&Spring記事人気No1
Kotlin
Kotlinのsettings.gradleファイルを完全解説!初心者でもわかるプロジェクト設定の基本
No.2
Java&Spring記事人気No2
Go言語
Swiftの配列(Array)の使い方を完全ガイド!初心者でもわかるデータのまとめ方
No.3
Java&Spring記事人気No3
Kotlin
KotlinのRoomで複雑なクエリを使いこなす!初心者でもわかる応用テクニック
No.4
Java&Spring記事人気No4
Go言語
Swiftの文字列操作を完全ガイド!初心者でもわかるStringの基本
No.5
Java&Spring記事人気No5
Swift
Swiftの高階関数map・filter・reduceを完全解説!初心者でもわかる配列操作の基本
No.6
Java&Spring記事人気No6
Go言語
Go言語のSQLインジェクション対策を完全解説!初心者でも安全なデータベース操作がわかる
No.7
Java&Spring記事人気No7
Go言語
Go言語のgo installコマンドの役割とインストール先の仕組みを徹底解説!
No.8
Java&Spring記事人気No8
Go言語
Go言語のインストール方法まとめ!Windows・Mac・Linux別に手順を丁寧に解説