Bersiap untuk menyiapkan Gateway API untuk Cloud Service Mesh
Halaman ini menjelaskan cara menginstal definisi resource kustom yang diperlukan untuk gateway ke cluster Anda.
Batasan
- Memiliki campuran cluster config-api
gateway
dan config-apiistio
dalam fleet yang sama tidak didukung. - Penemuan layanan dan load balancing multi-cluster tidak didukung untuk cluster
gateway
config-api. - Jika cluster diaktifkan menggunakan tanda
--management automatic
yang ada, cluster akan mulai menggunakanistio
API konfigurasi dan tidak dapat beralih kegateway
API. - Hanya FQDN yang didukung. Nama pendek tidak didukung.
Prasyarat
Sebagai titik awal, panduan ini mengasumsikan bahwa Anda telah
membuat project Google Cloud dan
menginstal kubectl
.
Sebelum memulai
- 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.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Kubernetes Engine, GKE Hub, and Cloud Service Mesh APIs.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Kubernetes Engine, GKE Hub, and Cloud Service Mesh APIs.
- Buat entri kubeconfig untuk cluster Anda:
- CLUSTER_NAME adalah nama cluster Anda
- LOCATION adalah lokasi cluster Anda
- PROJECT_ID adalah project ID cluster Anda
Buat cluster GKE:
gcloud container clusters create CLUSTER_NAME \ --location=LOCATION \ --enable-ip-alias \ --scopes=https://www.googleapis.com/auth/cloud-platform \ --release-channel=regular \ --project=PROJECT_ID \ --gateway-api=standard
dengan:
- CLUSTER_NAME adalah nama cluster Anda
- LOCATION adalah lokasi cluster Anda
- PROJECT_ID adalah project ID cluster Anda
Aktifkan Workload Identity Federation untuk GKE:
gcloud container clusters update CLUSTER_NAME \ --location LOCATION \ --workload-pool=PROJECT_ID.svc.id.goog
Jalankan Server Metadata GKE di node Anda:
gcloud container node-pools update default-pool \ --cluster=CLUSTER_NAME \ --location=LOCATION \ --workload-metadata=GKE_METADATA
Daftarkan cluster Anda ke fleet:
gcloud container hub memberships register CLUSTER_NAME \ --gke-cluster LOCATION/CLUSTER_NAME \ --project=PROJECT_ID
Verifikasi bahwa cluster terdaftar ke fleet:
gcloud container hub memberships list --project=PROJECT_ID
Outputnya mirip dengan:
NAME EXTERNAL_ID LOCATION my-cluster 91980bb9-593c-4b36-9170-96445c9edd39 us-west1
Berikan peran
trafficdirector.client
:gcloud projects add-iam-policy-binding PROJECT_ID \ --member "group:PROJECT_ID.svc.id.goog:/allAuthenticatedUsers/" \ --role "roles/trafficdirector.client"
Berikan peran
container.developer
:gcloud projects add-iam-policy-binding PROJECT_ID \ --member "serviceAccount:service-PROJECT_NUMBER@container-engine-robot.iam.gserviceaccount.com" \ --role "roles/container.developer"
dengan PROJECT_NUMBER adalah nomor project Anda.
Berikan peran
compute.networkAdmin
:gcloud projects add-iam-policy-binding PROJECT_ID \ --member "serviceAccount:service-PROJECT_NUMBER@container-engine-robot.iam.gserviceaccount.com" \ --role "roles/compute.networkAdmin"
dengan PROJECT_NUMBER adalah nomor project Anda.
Aktifkan fitur mesh:
gcloud container hub mesh enable --project PROJECT_ID
Perbarui mesh untuk menggunakan Gateway API:
gcloud alpha container fleet mesh update \ --config-api gateway \ --memberships CLUSTER_NAME \ --project PROJECT_ID
Verifikasi update dengan menjelaskan status resource Cloud Service Mesh:
gcloud alpha container fleet mesh describe
gcloud container clusters get-credentials CLUSTER_NAME --location LOCATION --project PROJECT_ID
dengan:
Membuat dan mendaftarkan cluster GKE
Siapkan izin
Perhatikan bahwa perintah berikut memberikan izin kepada semua pengguna terautentikasi, tetapi Anda dapat menggunakan Workload Identity Federation untuk GKE guna memberikan izin hanya kepada akun tertentu.
Mengaktifkan Cloud Service Mesh
Menginstal definisi resource kustom
Instal definisi resource kustom (CRD) GRPCRoute:
curl https://raw.githubusercontent.com/kubernetes-sigs/gateway-api/v1.1.0/config/crd/standard/gateway.networking.k8s.io_grpcroutes.yaml \
| kubectl apply -f -
Outputnya mirip dengan:
customresourcedefinition.apiextensions.k8s.io/grpcroutes.gateway.networking.k8s.io created