正式なドキュメントは英語版であり、この日本語訳はAI支援翻訳により作成された参考用のものです。日本語訳の一部の内容は人間によるレビューがまだ行われていないため、翻訳のタイミングにより英語版との間に差異が生じることがあります。最新かつ正確な情報については、英語版をご参照ください。

クラスター証明書を使用した、プロジェクトごとの複数のクラスター(非推奨)

  • プラン: Free、Premium、Ultimate
  • 提供形態: GitLab.com、GitLab Self-Managed

単一プロジェクトでの複数のKubernetesクラスターをwith cluster certificates(クラスター証明書で使用する)のは、GitLab 14.5でdeprecatedになりました。クラスターをGitLabに接続するには、Kubernetes向けGitLabエージェントを使用します。

複数のKubernetesクラスターをプロジェクトに関連付けることができます。そうすることで、開発、ステージング、本番環境など、異なる環境ごとに異なるクラスターを持つことができます。最初に行ったときと同じように別のクラスターを追加し、新しいクラスターを他と区別するスコープを設定するようにしてください。

環境スコープの設定

複数のKubernetesクラスターをプロジェクトに追加する場合、環境スコープを使用してそれらを区別する必要があります。環境スコープは、environments環境固有のCI/CD変数がどのように機能するかと同様に、クラスターを関連付けます。

デフォルトの環境スコープは*で、これはすべてのジョブが、環境に関係なく、そのクラスターを使用することを意味します。各スコープはプロジェクト内の単一のクラスターでのみ使用でき、そうでない場合は検証エラーが発生します。また、環境キーワードが設定されていないジョブは、どのクラスターにもアクセスできません。

たとえば、プロジェクトに次のKubernetesクラスターがあるとします:

クラスター環境スコープ
開発*
本番環境production

そして、次の環境が.gitlab-ci.ymlファイルに設定されています:

stages:
  - test
  - deploy

test:
  stage: test
  script: sh test

deploy to staging:
  stage: deploy
  script: make deploy
  environment:
    name: staging
    url: https://staging.example.com/

deploy to production:
  stage: deploy
  script: make deploy
  environment:
    name: production
    url: https://example.com/

結果:

  • Developmentクラスターの詳細は、deploy to stagingジョブで利用できます。
  • 本番環境クラスターの詳細は、deploy to productionジョブで利用できます。
  • 環境を定義していないため、testジョブではクラスターの詳細は利用できません。