Go言語

DockerでGoアプリをコンテナ化する手順とベストプラクティス

ⓘ本ページはプロモーションが含まれています

もっとスキルを活かしたいエンジニアへ

スポンサードリンク
働き方から選べる

無料で使えて良質な案件の情報収集ができるサービス

エンジニアの世界では、「いつでも動ける状態を作っておけ」とよく言われます。
技術やポートフォリオがあっても、自分に合う案件情報を日常的に見れていないと、いざ動こうと思った時に比較や判断が難しくなってしまいます。
普段から案件情報が集まる環境を作っておくと、良い案件が出た時にすぐ動きやすくなりますよ。
筆者自身も、メガベンチャー勤務時代に年収1,500万円を超えた経験があります。振り返ると、技術だけでなく「どんな案件や働き方があるか」を日頃から見ていたことが、キャリアの選択肢を広げるきっかけになりました。
このブログを読んでくれた方に感謝を込めて、実際に使っている情報収集サービスを紹介します。

フルリモート・週3日・高単価、どんな条件も妥協したくないなら

フリーランスボードに無料会員登録する

利用者10万人以上。業界最大規模45万件の案件。AIマッチ機能や無料の相場情報が人気。

年収800万円以上のキャリアアップ・ハイクラス正社員を視野に入れているなら

Beyond Careerに無料相談する

内定獲得率90%以上。紹介先企業とは役員クラスのコネクションがある安心と信頼できるエージェント。


スポンサードリンク

1️⃣ 前提条件とインストール確認

Docker の導入が正しく行われているか

上記コマンドでバージョン情報が表示されれば、ローカル環境はすぐにコンテナ開発へ移行できます。Docker Desktop/Docker Engine のインストール手順は公式ドキュメントを参照してください(Windows・macOS・Linux 共通)。


2️⃣ 公式 Golang イメージの選定と .dockerignore の活用

2-1. ベースイメージは何を選ぶべきか

イメージ 主な特徴 推奨理由
golang:1.22-alpine Alpine Linux 上の公式 Go 1.22 ビルダー。サイズ ≈ 210 MB(2024‑12 時点、Docker Hub の manifest list に基づく) アーカイブが小さく、Alpine のパッケージは最小限に抑えられるため攻撃対象が限定される。公式サポートなので脆弱性情報も迅速に提供される
golang:1.22 (Debian) Debian 系統のフルイメージ。サイズ ≈ 800 MB ビルドツールやローカルパッケージが豊富だが、不要なものまで含むため本番ランタイムには不向き
非公式・古いバージョン メンテナンスが止まっているケースが多い セキュリティパッチが提供されず、脆弱性リスクが高まる

ポイント:実際のサイズは docker pull golang:1.22-alpine 後に docker images で確認できます。30 MB と表記されている情報は古い Alpine のイメージ(Go ツールチェーン未含)です。

2-2. ビルドコンテキストを削減する .dockerignore

上記設定で Docker が転送するデータは数十 KB にまで削減でき、ビルド時間とネットワーク負荷が大幅に改善します。


3️⃣ マルチステージ Dockerfile の構成

3-1. ビルドステージ(依存取得とキャッシュ活用)

  • go.modgo.sum のみを先にコピーすることで、ソース変更があっても依存解決レイヤーは再利用されます。
  • ビルド時の一時パッケージ(git)は ビルダーだけ にインストールし、次のステージでは削除します。

3-2. ランタイムステージ(最小権限・サイズ最適化)

セキュリティ上のポイント

項目 内容
非 root ユーザー USER ディレクティブで UID 10001 の専用ユーザーを使用。コンテナ内の権限昇格が不可能になる
最小パッケージ ランタイムは alpine:3.19 + ca-certificates のみ。不要なシェルやビルドツールは含まれない
読み取り専用ファイルシステム docker run --read-only … オプションと併せて使用すると、コンテナ内部への書き込みは明示的に許可したボリュームだけになる
Capabilities の削減 --cap-drop ALL で不要な Linux ケーパビリティを除外(Delve デバッグ時は例外)

3-3. 完成イメージのサイズ目安

  • ビルダー段階:≈ 210 MB
  • ランタイム段階:約 30 MB(バイナリと ca‑certificates のみ)

実際に docker images my-go-app とすれば、最終イメージのサイズが確認できます。


4️⃣ ビルド・デプロイのベストプラクティス

4-1. Docker Build の推奨コマンド

  • --no-cache は頻繁に変更しない限り使用しない方がキャッシュ効果でビルド時間を短縮できます。
  • CI/CD パイプラインでは docker buildx bake --push でマルチプラットフォームイメージも同時に生成可能です。

4-2. Docker Run の安全な起動例

  • --read-only--cap-drop ALL により、攻撃者がコンテナ内で権限昇格を試みても実行できる操作は極めて限定的です。
  • 必要な書き込み領域(ログや一時ファイル)は -v $(pwd)/data:/app/data:rw のようにボリュームで明示的にマウントします。

4-3. イメージサイズ削減テクニック

手法 効果
ビルダーから不要パッケージを削除 (apk del) 約 10‑15 MB の削減
--squash(Docker 23.0+)でレイヤー統合 最大 30 % のサイズ低減
strip コマンドでバイナリのシンボル情報除去 (go build -ldflags="-s -w") バイナリ自体が約 20 % 小さくなる

実践例
dockerfile
RUN apk add --no-cache git && \
go mod download && \
apk del git # ビルダーから git を除去


5️⃣ ローカルデバッグ環境の構築(Docker‑Compose & VS Code Remote Containers)

5-1. docker-compose.yml の最小構成

  • command に Delve の起動オプションを直接記述することで、docker compose up だけでデバッグ可能です。
  • security_opt: no-new-privileges:true は Linux カーネル機能で、プロセスが新しい特権を取得できなくします。

5-2. VS Code Remote‑Containers 設定(devcontainer.json)

  • forwardPorts により VS Code のデバッグ UI が自動的にホスト側ポートへ接続。
  • runArgs--cap-add=SYS_PTRACE は Delve がプロセスをトレースするために必須ですが、デバッグ以外の本番環境では除去すべきです。

外部参照について:上記設定は Qiita 記事「Go アプリを Docker でデバッグ」等で紹介されている手順と同等ですが、本稿内に全コードと解説を掲載しているため、リンク先の内容確認が不要です。


6️⃣ まとめ & 次のアクション

項目 実施すべきこと
Docker の導入 docker --version が表示されたら次へ
ベースイメージ選定 golang:1.22-alpine(≈210 MB) を使用し、.dockerignore でコンテキストを最小化
マルチステージ Dockerfile ビルダーとランタイムを分離し、非 root ユーザー・read‑only FS・capability 削減を実装
ビルドコマンド docker build --pull --rm -t my-go-app:1.0.0 . を CI に組み込む
デプロイ docker run 時に --read-only--cap-drop ALL--user オプションを必ず付与
サイズ最適化 ビルダーの一時パッケージ削除と --squash の活用
ローカルデバッグ docker‑compose + VS Code Remote Containers で即座にブレークポイント設定可能な環境を構築
運用フェーズ イメージの定期スキャン(Trivy 等)と、ベースイメージ更新時の CI 再ビルドを自動化

これらを順に実装すれば、軽量・高速・最小権限 の Go コンテナが完成し、開発から本番まで一貫した安全性を確保できます。ぜひ本稿の手順をローカル環境で試し、CI/CD パイプラインへ組み込んでみてください。

スポンサードリンク

もっとスキルを活かしたいエンジニアへ

スポンサードリンク
働き方から選べる

無料で使えて良質な案件の情報収集ができるサービス

エンジニアの世界では、「いつでも動ける状態を作っておけ」とよく言われます。
技術やポートフォリオがあっても、自分に合う案件情報を日常的に見れていないと、いざ動こうと思った時に比較や判断が難しくなってしまいます。
普段から案件情報が集まる環境を作っておくと、良い案件が出た時にすぐ動きやすくなりますよ。
筆者自身も、メガベンチャー勤務時代に年収1,500万円を超えた経験があります。振り返ると、技術だけでなく「どんな案件や働き方があるか」を日頃から見ていたことが、キャリアの選択肢を広げるきっかけになりました。
このブログを読んでくれた方に感謝を込めて、実際に使っている情報収集サービスを紹介します。

フルリモート・週3日・高単価、どんな条件も妥協したくないなら

フリーランスボードに無料会員登録する

利用者10万人以上。業界最大規模45万件の案件。AIマッチ機能や無料の相場情報が人気。

年収800万円以上のキャリアアップ・ハイクラス正社員を視野に入れているなら

Beyond Careerに無料相談する

内定獲得率90%以上。紹介先企業とは役員クラスのコネクションがある安心と信頼できるエージェント。


-Go言語