フリート全体にリソースをデプロイする
このチュートリアルでは、フリート パッケージを使用して、クラスタのフリート全体に Kubernetes リソース マニフェストをデプロイする方法について説明します。Config Sync のフリート パッケージなどの GitOps ツールを使用すると、多数のクラスタにわたって構成管理をスケールアップできます。
このチュートリアルでは、次のタスクを行います。
- Git リポジトリを Cloud Build に接続する
- クラスタを作成してフリートに登録する
- Config Sync をフリートのデフォルトとしてインストールする
- リポジトリからクラスタのフリートにリソースをデプロイする
始める前に
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
Install the Google Cloud CLI.
-
外部 ID プロバイダ(IdP)を使用している場合は、まずフェデレーション ID を使用して gcloud CLI にログインする必要があります。
-
gcloud CLI を初期化するには、次のコマンドを実行します。
gcloud init
-
Create or select a Google Cloud project.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_ID
with a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_ID
with your Google Cloud project name.
-
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the GKE Enterprise, Config Delivery (fleet packages), Cloud Build, Developer Connect APIs:
gcloud services enable anthos.googleapis.com
configdelivery.googleapis.com cloudbuild.googleapis.com developerconnect.googleapis.com -
Install the Google Cloud CLI.
-
外部 ID プロバイダ(IdP)を使用している場合は、まずフェデレーション ID を使用して gcloud CLI にログインする必要があります。
-
gcloud CLI を初期化するには、次のコマンドを実行します。
gcloud init
-
Create or select a Google Cloud project.
-
Create a Google Cloud project:
gcloud projects create PROJECT_ID
Replace
PROJECT_ID
with a name for the Google Cloud project you are creating. -
Select the Google Cloud project that you created:
gcloud config set project PROJECT_ID
Replace
PROJECT_ID
with your Google Cloud project name.
-
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the GKE Enterprise, Config Delivery (fleet packages), Cloud Build, Developer Connect APIs:
gcloud services enable anthos.googleapis.com
configdelivery.googleapis.com cloudbuild.googleapis.com developerconnect.googleapis.com - GitHub アカウントを作成するか、アカウントへのアクセス権を取得します。
ウェブブラウザで GitHub を開きます。
必要に応じて GitHub アカウントにログインします。GitHub で他の組織またはチームにアクセスできる場合は、個人アカウントでリポジトリを作成していることを確認してください。
ツールバーで [追加] add を選択し、[新しいリポジトリ] をクリックします。
リポジトリの名前として「
fleet-package-tutorial
」と入力します。リポジトリの公開設定として [公開] を選択したままにします。
[リポジトリを作成] を選択します。
Google Cloud コンソールで Cloud Build ページを開き、[リポジトリ] を選択します。
第 2 世代の [リポジトリ] ページに移動します。必要に応じて、[リポジトリ(第 2 世代)を表示] を選択します。
[ホスト接続を作成] をクリックします。
[リージョン] メニューで、リージョンとして [us-central1(アイオワ)] を選択します。
[名前] フィールドに、接続の名前として「
fleet-package-quickstart-connection
」を入力します。[接続] をクリックします。
Cloud Build を GitHub アカウントに初めて接続する場合は、次の操作を行います。
- GitHub OAuth トークンのリクエストを承認します。トークンは、Cloud Build GitHub 接続で使用するために Secret Manager に保存されます。[続行] をクリックします。
- GitHub リポジトリに Cloud Build をインストールします。[新しいアカウントでインストール] を選択します。
- 新しい GitHub ウィンドウが開きます。ここで、先ほど Cymbal Bank のフォークを作成した GitHub アカウントを選択します。本番環境では、アクセス権を委任された他のアカウントまたはリポジトリを選択できます。
- 認証プロンプトに従って、GitHub で本人確認を行います。
- Cloud Build リポジトリ アクセスの GitHub ウィンドウで、[Only select repositories] を選択します。
- リポジトリが一覧表示されたプルダウン メニューから、
fleet-package-tutorial
リポジトリを選択します。 - [保存] をクリックします。
Google Cloud コンソールの Cloud Build ページで、[リポジトリをリンク] をクリックして、新しい Git リポジトリを Cloud Build に接続します。
[接続] メニューで、[
fleet-package-quickstart-connection
] を選択します。[リポジトリ] メニューで、
fleet-package-tutorial
リポジトリを選択します。[リンク] をクリックします。
GKE クラスタを作成します。
gcloud container clusters create-auto cluster1 \ --project=PROJECT_ID \ --region=REGION \ --fleet-project=PROJECT_ID \ --release-channel=rapid
次のように置き換えます。
PROJECT_ID
: プロジェクト ID。REGION
は、クラスタを作成するリージョン(us-central1
など)に置き換えます。
2 番目の GKE クラスタを作成します。
gcloud container clusters create-auto cluster2 \ --project=PROJECT_ID \ --region=REGION \ --fleet-project=PROJECT_ID \ --release-channel=rapid
Google Cloud コンソールで、[機能マネージャー] ページに移動します。
[Config Sync] ペインで、[構成] をクリックします。
[フリートの設定をカスタマイズ] をクリックします。表示されるダイアログで、インストールする Config Sync のバージョンを選択します。
[構成] をクリックします。
[フリートの設定を構成] 確認ダイアログで、[確認] をクリックします。以前に Config Sync を有効にしていない場合は、[確認] をクリックして
anthosconfigmanagement.googleapis.com
API を有効にします。[フリート内のクラスタ] テーブルで、両方のクラスタを選択し、[フリートの設定に同期] をクリックします。これにより、構成した設定で両方のクラスタに Config Sync がインストールされます。
クラスタの同期には数分かかることがあります。Config Sync が [インストール済み] と表示されたら、次の手順に進みます。
サービス アカウントを作成します。
gcloud iam service-accounts create "quickstart-service-account"
リソース バンドル パブリッシャー ロールの IAM ポリシー バインディングを追加して、Git リポジトリからリソースを取得する権限をサービス アカウントに付与します。
gcloud projects add-iam-policy-binding PROJECT_ID \ --member="serviceAccount:quickstart-service-account@PROJECT_ID.iam.gserviceaccount.com" \ --role='roles/configdelivery.resourceBundlePublisher'
メッセージが表示されたら、ポリシーの条件として
None
を選択します。ログ書き込みロールの IAM ポリシー バインディングを追加して、サービス アカウントにログの書き込み権限を付与します。
gcloud projects add-iam-policy-binding PROJECT_ID \ --member="serviceAccount:quickstart-service-account@PROJECT_ID.iam.gserviceaccount.com" \ --role='roles/logging.logWriter'
メッセージが表示されたら、ポリシーの条件として
None
を選択します。GitHub リポジトリのウェブブラウザ ウィンドウで、[Add file]、[Create new file] の順にクリックします。
ファイルに
deployment.yaml
という名前を付け、次のコンテンツを貼り付けます。apiVersion: apps/v1 kind: Deployment metadata: name: nginx-deployment spec: replicas: 3 selector: matchLabels: app: nginx template: metadata: labels: app: nginx spec: containers: - image: nginx:1.14.2 name: nginx ports: - containerPort: 80
[Commit changes...] をクリックします。
確認ダイアログで、[Commit directly to the
main
branch] を選択したままにして、[Commit changes] をクリックします。リポジトリのメインページで、サイドバーから [Releases] を選択します。
ページの上部で [Draft a new release] を選択します。
[Choose a tag] メニューを選択し、タグとして「
v1.0.0
」と入力します。[Create new tag] をクリックします。[Publish release] をクリックします。
このフリート パッケージにはセレクタ フィールドがないため、フリート内のすべてのクラスタがターゲットになります。また、フリートに追加されるクラスタには、nginx Deployment が自動的に追加されます。
Cloud Shell で、次の内容を含むファイルを
fleet-package.yaml
という名前で作成します。resourceBundleSelector: cloudBuildRepository: name: projects/PROJECT_ID/locations/us-central1/connections/fleet-package-quickstart-connection/repositories/REPOSITORY_NAME tag: v1.0.0 serviceAccount: projects/PROJECT_ID/serviceAccounts/quickstart-service-account@PROJECT_ID.iam.gserviceaccount.com path: target: fleet: project: projects/PROJECT_ID rolloutStrategy: rolling: maxConcurrent: 1
REPOSITORY_NAME
は、Cloud Build のリポジトリ名に置き換えます。通常はUSERNAME-REPOSITORY_NAME
形式です。フリート パッケージを作成して、ロールアウトを開始します。
gcloud alpha container fleet packages create fp-nginx \ --source=fleet-package.yaml \ --project=PROJECT_ID
フリート パッケージが作成されたことを確認します。
gcloud alpha container fleet packages list
表示されたリンクをクリックすると、Cloud Build ジョブのストリーミング ログを表示できます。
フリート パッケージが、フリート全体で Kubernetes リソースのロールアウトを開始します。
Google Cloud コンソールの [Google Kubernetes Engine] ページで、[ワークロード] ページに移動すると、すべての GKE クラスタにデプロイされているワークロードの集約ビューが表示されます。
ワークロードが使用可能になるまでに数分かかることがあります。Autopilot が新しいデプロイのリソース リクエストを調整しているときに、可用性エラーが発生することもあります。
フリート パッケージ定義で
maxConcurrent:
が1
に設定されているため、フリート パッケージ API は、1 つのクラスタにnginx-deployment
が完全にデプロイされるまで待機してから、2 番目のクラスタへのデプロイを開始します。ロールアウト戦略をmaxConcurrent: 2
以上に変更した場合、リソースは両方のクラスタに同時にデプロイされます。数分後、両方のクラスタの
nginx-deployment
に 2 つの新しいワークロードが表示されます。ページの更新が必要になる場合があります。Cymbal Bank の GitHub フォークのウェブブラウザ ウィンドウで、リポジトリ名の下にある [Settings] をクリックします。
[General settings] ページ(デフォルトで選択されています)で、[Danger Zone] セクションに移動し、[Delete this repository] をクリックします。
[I want to delete this repository] をクリックします。
警告を読み、[I have read and understand these effects] をクリックします。
削除されるリポジトリが正しいことを確認するには、テキスト フィールドに、リポジトリの名前を入力します。
[Delete this repository] をクリックします。
- フリート パッケージの詳細を確認する。
- フリート パッケージをデプロイする方法の詳細を確認する。
- スケーラビリティが高いアプリのチュートリアルをお試しください。これは、GKE Enterprise で最新のアプリケーション環境のデプロイ、実行、管理を行う方法を学ぶ一連のチュートリアルです。これには、フリート パッケージを使用して構成変更をスケールアップする方法を説明するチェンジ マネジメントを一元化するチュートリアルが含まれています。
費用
このドキュメントでは、課金対象である次の Google Cloudコンポーネントを使用します。
料金計算ツールを使うと、予想使用量に基づいて費用の見積もりを生成できます。
Git に接続する
Git リポジトリには、フリート全体にデプロイするリソースが含まれています。フリート パッケージを使用してこうしたリソースをデプロイするには、Git リポジトリを Cloud Build に接続する必要があります。
Git リポジトリを作成する
このチュートリアルでは、Git プロバイダとして GitHub を使用します。新しい GitHub リポジトリを作成する手順は次のとおりです。
リポジトリを Cloud Build に接続する
Config Sync のフリート パッケージ サービスは、Cloud Build を使用して Git リポジトリから Kubernetes リソースを同期して取得します。
GitHub リポジトリを Cloud Build に接続するには、次の手順を行います。
フリートを設定する
このセクションでは、クラスタを作成してフリートに登録し、Config Sync をフリート パッケージとしてインストールすることで、フリートを設定します。
クラスタを作成する
このチュートリアルでは、フリート パッケージを使用して複数のクラスタにリソースをデプロイする方法を示すために、2 つのクラスタを作成する方法について説明します。
2 つのクラスタを作成してプロジェクトのフリートに登録するには:
Config Sync をフリートのデフォルトとしてインストールする
フリート パッケージ サービスを使用するには、両方のクラスタに Config Sync がインストールされている必要があります。次の手順を行うと、Config Sync を複数のクラスタに一度にインストールできます。また、今後フリートに登録されるクラスタにもインストールできます。
Cloud Build のサービス アカウントを設定する
サービス アカウントを作成して Cloud Build に必要な権限を付与する手順は次のとおりです。
フリート全体にリソースをデプロイする
このチュートリアルでは、nginx デプロイを含む Kubernetes マニフェストを Git リポジトリに追加し、リリースを公開してから、nginx アプリケーションをデプロイするフリート パッケージを作成します。
Kubernetes マニフェストをリポジトリに commit する
リソースを GitHub に追加してリリースを公開する手順は次のとおりです。
フリート パッケージを使用してリソースをクラスタにデプロイする
新しいリソースをデプロイするには、新しいフリート パッケージを作成します。
フリート パッケージを使用した別のデプロイ戦略も考えてみましょう。たとえば、フリートに新しいクラスタを追加して、ワークロードがその新しいクラスタに自動的にデプロイされることを確認できます。デプロイ戦略とバリエーションの詳細については、フリート パッケージをデプロイするをご覧ください。
クリーンアップ
このページで使用したリソースについて、 Google Cloud アカウントに課金されないようにするには、リソースを含む Google Cloud プロジェクトを削除します。
このチュートリアルで使用したリソースについて Google Cloud アカウントに課金されないようにするには、作成したプロジェクトを削除します。
Delete a Google Cloud project:
gcloud projects delete PROJECT_ID
リポジトリを削除するには、次の操作を行います。