フリート全体にリソースをデプロイする
このチュートリアルでは、フリート パッケージを使用して、クラスタのフリート全体に 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.
-
To use a federated identity with the gcloud CLI, you must first configure the tool to use a federated identity.
For more information, see Browser-based sign-in with the gcloud CLI.
-
To initialize the gcloud CLI, run the following command:
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.
-
To use a federated identity with the gcloud CLI, you must first configure the tool to use a federated identity.
For more information, see Browser-based sign-in with the gcloud CLI.
-
To initialize the gcloud CLI, run the following command:
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 アカウントを作成するか、アカウントへのアクセス権を取得します。
料金
このドキュメントでは、Google Cloud の次の課金対象のコンポーネントを使用します。
料金計算ツールを使うと、予想使用量に基づいて費用の見積もりを生成できます。
Git に接続する
Git リポジトリには、フリート全体にデプロイするリソースが含まれています。これらのリソースをフリート パッケージでデプロイするには、Git リポジトリを Cloud Build に接続する必要があります。
Git リポジトリを作成する
このチュートリアルでは、Git プロバイダとして GitHub を使用します。新しい GitHub リポジトリを作成するには、次の操作を行います。
ウェブブラウザで GitHub を開きます。
必要に応じて GitHub アカウントにログインします。GitHub で他の組織またはチームにアクセスできる場合は、個人アカウントでリポジトリを作成していることを確認してください。
ツールバーで [追加] add を選択し、[新しいリポジトリ] をクリックします。
リポジトリの名前として
fleet-package-tutorial
と入力します。リポジトリの公開設定は [公開] のままにします。
[リポジトリを作成] を選択します。
リポジトリを Cloud Build に接続する
Config Sync のフリート パッケージ サービスは、Cloud Build を使用して Git リポジトリから Kubernetes リソースを同期して取得します。
GitHub リポジトリを Cloud Build に接続するには、次の操作を行います。
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
リポジトリを選択します。[リンク] をクリックします。
フリートを設定する
このセクションでは、クラスタを作成してフリートに登録し、Config Sync をフリート パッケージとしてインストールして、フリートを設定します。
クラスタを作成する
このチュートリアルでは、フリート パッケージを使用して複数のクラスタにリソースをデプロイする方法を示します。そのために、2 つのクラスタを作成します。
2 つのクラスタを作成してプロジェクトのフリートに登録するには:
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
Config Sync をフリートのデフォルトとしてインストールする
フリート パッケージ サービスを使用するには、両方のクラスタに Config Sync をインストールする必要があります。複数のクラスタと、フリートに登録される今後のクラスタに Config Sync を一度にインストールするには、次の操作を行います。
Google Cloud コンソールで、[機能マネージャー] ページに移動します。
[Config Sync] ペインで、[構成] をクリックします。
[フリートの設定をカスタマイズ] をクリックします。表示されたダイアログで、[自動アップグレード] を選択します。この設定により、クラスタにフリート パッケージをサポートする Config Sync バージョンが確実にインストールされます。
[変更を保存] をクリックします。
[構成] をクリックします。
[フリートの設定を構成] 確認ダイアログで、[確認] をクリックします。以前に Config Sync を有効にしていない場合は、[確認] をクリックして
anthosconfigmanagement.googleapis.com
API を有効にします。[フリート内のクラスタ] テーブルで、両方のクラスタを選択し、[フリートの設定に同期] をクリックします。これにより、構成した設定で両方のクラスタに Config Sync がインストールされます。
クラスタの同期には数分かかることがあります。Config Sync が [インストール済み] と表示されたら、次のステップに進みます。
Cloud Build のサービス アカウントを設定する
サービス アカウントを作成して Cloud Build に必要な権限を付与する手順は次のとおりです。
サービス アカウントを作成します。
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
を選択します。
フリート全体にリソースをデプロイする
このチュートリアルでは、nginx Deployment を含む Kubernetes マニフェストを Git リポジトリに追加し、リリースを公開してから、フリート パッケージを作成して nginx アプリケーションをデプロイします。
Kubernetes マニフェストをリポジトリに commit する
リソースを GitHub に追加してリリースを公開する手順は次のとおりです。
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.yaml \ --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 は、nginx-deployment
が 1 つのクラスタに完全にデプロイされるまで待ってから、2 番目のクラスタへのデプロイを開始します。ロールアウト戦略をmaxConcurrent: 2
以上に変更すると、リソースは両方のクラスタに同時にデプロイされます。数分後、両方のクラスタに
nginx-deployment
の新しいワークロードが 2 つ表示されます。ページの更新が必要になる場合があります。
フリート パッケージを使用した別のデプロイ戦略も考えてみましょう。たとえば、フリートに新しいクラスタを追加して、ワークロードがその新しいクラスタに自動的にデプロイされることを確認できます。デプロイ戦略とバリエーションの詳細については、フリート パッケージをデプロイするをご覧ください。
クリーンアップ
このページで使用したリソースについて、Google Cloud アカウントに課金されないようにするには、Google Cloud プロジェクトとそのリソースをまとめて削除してください。
このチュートリアルで使用したリソースに対して Google Cloud アカウントに課金されないようにするには、作成したプロジェクトを削除します。
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
リポジトリを削除する手順は次のとおりです。
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 で最新のアプリケーション環境をデプロイ、実行、管理する方法について説明します。これには、フリート パッケージを使用して構成変更をスケールアップするチェンジ マネジメントを一元化するチュートリアルが含まれています。