GitLab Runner: Docker-in-DockerでDockerイメージをビルドする

このドキュメントはDockerイメージのビルドガイドの一部です。完全なガイドはこちらからご覧いただけます:StackheroランナーとDocker-in-Dockerを使って、GitLab CI/CDパイプラインからDockerイメージをビルドおよびプッシュする方法

👋 Stackhero ドキュメントへようこそ!

Stackhero では、GitLab Runner cloud を簡単にご利用いただけるソリューションとしてご提供しています。GitLab CI/CD ジョブを効率的に処理できるよう設計されています。主な特長は以下の通りです:

  • 無制限の CI/CD 分数:分単位の課金はありませんので、必要なときにいつでもパイプラインを実行できます。
  • 複数ジョブの同時実行:複数のジョブを同時に実行し、パイプライン全体の処理速度を向上させます。
  • Docker executorDocker-in-Docker サポート:コンテナイメージのビルドやプッシュを効率化します。
  • GitLab.com およびあらゆる セルフホスト型 GitLab インスタンスに対応。
  • 高速な NVMe/SSD ディスクを搭載した プライベート専用 VM で、安定したビルド環境を提供します。
  • 🇪🇺 ヨーロッパ および 🇺🇸 USA リージョンでご利用可能です。

時間を節約:最初の GitLab Runner を接続し、数分でパイプラインの実行を開始できます!

以下は、リポジトリに追加できるサンプルの.gitlab-ci.ymlです。この設定では、プロジェクトのルートにあるDockerfileをビルドします。

build-image:
  stage: build
  image: docker:27
  services:
    - docker:27-dind
  variables:
    DOCKER_TLS_CERTDIR: "/certs"
  before_script:
    - docker info
  script:
    # "my-image"を任意のイメージ名に置き換えてください:
    - docker build -t my-image .
    # 必要に応じて、ビルドしたイメージで簡単なスモークテストを実行できます:
    # - docker run --rm my-image /path/to/tests

この構成では、docker:27-dindサービスがDockerデーモンを起動します。変数DOCKER_TLS_CERTDIR: "/certs"は、ジョブとDockerデーモン間の安全なTLS接続を有効にします。