Halaman ini menjelaskan cara menyiapkan dan bersiap menggunakan driver CSI Cloud Storage FUSE untuk GKE.
Untuk menggunakan driver CSI Cloud Storage FUSE, lakukan langkah-langkah berikut:
Buat bucket Cloud Storage
Jika Anda belum melakukannya, buat bucket Cloud Storage. Anda akan memasang bucket ini sebagai volume di cluster GKE Anda. Untuk meningkatkan performa, tetapkan Jenis lokasi ke Region, lalu pilih region yang cocok dengan cluster GKE Anda.
Mengaktifkan driver CSI Cloud Storage FUSE
Ikuti langkah-langkah berikut, bergantung pada apakah Anda menggunakan cluster GKE Autopilot atau Standard. Sebaiknya gunakan cluster Autopilot untuk mendapatkan pengalaman Kubernetes yang terkelola sepenuhnya. Untuk memilih mode yang paling sesuai untuk workload Anda, lihat Memilih mode operasi GKE.
Autopilot
Driver CSI Cloud Storage FUSE diaktifkan secara default untuk cluster Autopilot. Anda dapat langsung membuka Mengonfigurasi akses ke bucket Cloud Storage.
Standar
Jika cluster Standard Anda mengaktifkan driver CSI Cloud Storage FUSE, lanjutkan ke bagian Mengonfigurasi akses ke bucket Cloud Storage.
Driver CSI Cloud Storage FUSE tidak diaktifkan secara default di cluster Standard. Untuk membuat cluster Standard dengan driver CSI Cloud Storage FUSE diaktifkan, Anda dapat menggunakan perintah gcloud container clusters create
:
gcloud container clusters create CLUSTER_NAME \
--addons GcsFuseCsiDriver \
--cluster-version=VERSION \
--location=LOCATION \
--workload-pool=PROJECT_ID.svc.id.goog
Ganti kode berikut:
CLUSTER_NAME
: nama cluster Anda.VERSION
: nomor versi GKE. Anda harus memilih 1.24 atau yang lebih baru.LOCATION
: region atau zona Compute Engine untuk cluster.PROJECT_ID
: project ID Anda.
Untuk mengaktifkan driver di cluster Standard yang sudah ada, gunakan perintah gcloud container clusters update
:
gcloud container clusters update CLUSTER_NAME \
--update-addons GcsFuseCsiDriver=ENABLED \
--location=LOCATION
Untuk memverifikasi bahwa driver CSI Cloud Storage FUSE diaktifkan di cluster Anda, jalankan perintah berikut:
gcloud container clusters describe CLUSTER_NAME \
--location=LOCATION \
--project=PROJECT_ID \
--format="value(addonsConfig.gcsFuseCsiDriverConfig.enabled)"
Mengonfigurasi akses ke bucket Cloud Storage
Driver CSI Cloud Storage FUSE menggunakan Workload Identity Federation untuk GKE sehingga Anda dapat menetapkan izin terperinci tentang cara Pod GKE Anda dapat mengakses data yang disimpan di Cloud Storage.
Agar bucket Cloud Storage Anda dapat diakses oleh cluster GKE, lakukan autentikasi menggunakan Workload Identity Federation untuk GKE dengan bucket Cloud Storage yang ingin Anda pasang dalam spesifikasi Pod:
- Jika Anda belum mengaktifkan Workload Identity Federation untuk GKE, ikuti langkah-langkah ini untuk mengaktifkannya. Jika Anda ingin menggunakan node pool yang ada, aktifkan Workload Identity Federation for GKE secara manual di node pool setelah mengaktifkan Workload Identity Federation for GKE di cluster.
Dapatkan kredensial untuk cluster Anda:
gcloud container clusters get-credentials CLUSTER_NAME \ --location=LOCATION
Ganti kode berikut:
CLUSTER_NAME
: nama cluster Anda yang telah mengaktifkan Workload Identity Federation untuk GKE.LOCATION
: region atau zona Compute Engine untuk cluster.
Buat namespace yang akan digunakan untuk Akun Layanan Kubernetes. Anda juga dapat menggunakan namespace
default
atau namespace yang sudah ada.kubectl create namespace NAMESPACE
Ganti
NAMESPACE
dengan nama namespace Kubernetes untuk Akun Layanan Kubernetes.Buat Akun Layanan Kubernetes yang akan digunakan aplikasi Anda. Anda juga dapat menggunakan Akun Layanan Kubernetes yang sudah ada di namespace mana pun, termasuk Akun Layanan Kubernetes
default
.kubectl create serviceaccount KSA_NAME \ --namespace NAMESPACE
Ganti
KSA_NAME
dengan nama ServiceAccount Kubernetes Anda.Berikan salah satu peran IAM untuk Cloud Storage ke Akun Layanan Kubernetes. Ikuti langkah-langkah berikut, bergantung pada apakah Anda memberikan akses Kubernetes ServiceAccount hanya ke bucket Cloud Storage tertentu, atau akses global ke semua bucket dalam project.
Akses bucket tertentu
gcloud storage buckets add-iam-policy-binding gs://BUCKET_NAME \ --member "principal://iam.googleapis.com/projects/PROJECT_NUMBER/locations/global/workloadIdentityPools/PROJECT_ID.svc.id.goog/subject/ns/NAMESPACE/sa/KSA_NAME" \ --role "ROLE_NAME"
Ganti kode berikut:
BUCKET_NAME
: nama bucket Cloud Storage Anda.PROJECT_NUMBER
: nomor project numerik cluster GKE Anda. Untuk menemukan nomor project Anda, lihat Mengidentifikasi project.PROJECT_ID
: project ID cluster GKE Anda.NAMESPACE
: nama namespace Kubernetes untuk Akun Layanan Kubernetes.KSA_NAME
: nama ServiceAccount Kubernetes baru Anda.ROLE_NAME
: peran IAM yang akan ditetapkan ke ServiceAccount Kubernetes Anda.- Untuk beban kerja hanya baca, gunakan peran Storage Object Viewer (
roles/storage.objectViewer
). - Untuk beban kerja baca-tulis, gunakan peran Storage Object User (
roles/storage.objectUser
).
- Untuk beban kerja hanya baca, gunakan peran Storage Object Viewer (
Akses bucket global
gcloud projects add-iam-policy-binding GCS_PROJECT \ --member "principal://iam.googleapis.com/projects/PROJECT_NUMBER/locations/global/workloadIdentityPools/PROJECT_ID.svc.id.goog/subject/ns/NAMESPACE/sa/KSA_NAME" \ --role "ROLE_NAME"
Ganti kode berikut:
GCS_PROJECT
: project ID bucket Cloud Storage Anda.PROJECT_NUMBER
: nomor project numerik cluster GKE Anda. Untuk menemukan nomor project Anda, lihat Mengidentifikasi project.PROJECT_ID
: project ID cluster GKE Anda.NAMESPACE
: nama namespace Kubernetes untuk Akun Layanan Kubernetes.KSA_NAME
: nama ServiceAccount Kubernetes baru Anda.ROLE_NAME
: peran IAM yang akan ditetapkan ke ServiceAccount Kubernetes Anda.- Untuk beban kerja hanya baca, gunakan peran Storage Object Viewer (
roles/storage.objectViewer
). - Untuk beban kerja baca-tulis, gunakan peran Storage Object User (
roles/storage.objectUser
).
- Untuk beban kerja hanya baca, gunakan peran Storage Object Viewer (
Langkah berikutnya
- Memecahkan masalah Cloud Storage FUSE
- Mengoptimalkan Cloud Storage FUSE untuk performa
- Pelajari cara memasang bucket Cloud Storage dengan menentukan bucket secara inline dengan spesifikasi Pod.
- Pelajari cara memasang bucket Cloud Storage menggunakan resource PersistentVolume.
- Pelajari lebih lanjut cara mengonfigurasi aplikasi untuk menggunakan Workload Identity Federation for GKE.