Halaman ini menunjukkan cara membuat cluster admin untuk digunakan di domain topologi Google Distributed Cloud. Cluster admin mengelola cluster pengguna yang menjalankan beban kerja Anda. Google Distributed Cloud versi 1.31 atau yang lebih tinggi diperlukan untuk menggunakan domain topologi.
Penyiapan domain topologi mengharuskan Anda mengaktifkan cluster lanjutan. Perhatikan batasan berikut pada pratinjau cluster lanjutan:
- Anda dapat mengaktifkan cluster lanjutan pada saat pembuatan cluster untuk cluster 1.31 baru saja.
- Setelah cluster lanjutan diaktifkan, Anda tidak akan dapat mengupgrade cluster ke 1.32. Aktifkan cluster lanjutan hanya di lingkungan pengujian.
Halaman ini ditujukan untuk Admin, Arsitek, dan Operator yang menyiapkan, memantau, dan mengelola infrastruktur teknologi. Untuk mempelajari lebih lanjut peran umum dan contoh tugas yang kami referensikan dalam konten, lihat Peran dan tugas pengguna GKE umum. Google Cloud
Untuk mengetahui detail selengkapnya tentang cluster admin, lihat ringkasan penginstalan.
Ringkasan prosedur
Berikut adalah langkah-langkah utama yang terlibat dalam pembuatan cluster admin:
- Isi file konfigurasi admin Anda
- Tentukan detail untuk cluster admin baru dengan menyelesaikan file konfigurasi cluster admin.
- Isi file konfigurasi infrastruktur vSphere Anda
- Tentukan detail tentang domain topologi Anda dalam file konfigurasi infrastruktur vSphere.
- Isi file blok IP Anda
- Tentukan alamat IP untuk gateway, netmask, dan node bidang kontrol dalam file blok IP.
- Mendapatkan image OS
- Download paket Google Distributed Cloud normal. Kemudian, jalankan
gkectl prepare
, yang mengimpor image OS ke vSphere, dan mengirimkan image container ke registry pribadi jika berlaku.
- Buat cluster admin.
- Gunakan
gkectl
untuk membuat cluster admin baru seperti yang ditentukan dalam file konfigurasi yang telah selesai. Saat membuat cluster admin, Google Distributed Cloud akan men-deploy cluster Kubernetes in Docker (kind) untuk menghosting sementara pengontrol Kubernetes yang diperlukan untuk membuat cluster admin. Cluster sementara ini disebut cluster bootstrap. Cluster pengguna dibuat dan diupgrade oleh admin pengelola tanpa menggunakan cluster bootstrap.
- Pastikan cluster admin Anda berjalan.
- Gunakan
kubectl
untuk melihat node cluster Anda.
Di akhir prosedur ini, Anda akan memiliki cluster admin yang berjalan dan dapat digunakan untuk membuat dan mengelola cluster pengguna di domain topologi.
Sebelum memulai
Pastikan Anda telah menyiapkan dan dapat login ke workstation admin seperti yang dijelaskan dalam artikel Membuat workstation admin. Workstation admin memiliki alat yang Anda butuhkan untuk membuat cluster admin. Lakukan semua langkah dalam dokumen ini di workstation admin Anda.
Tinjau dokumen perencanaan alamat IP. Pastikan Anda memiliki cukup alamat IP yang tersedia untuk tiga node bidang kontrol dan VIP bidang kontrol.
Konfigurasi load balancer Anda untuk load balancing manual. Load balancer harus disiapkan sebelum Anda membuat cluster admin.
Lihat bagian
privateRegistry
dan putuskan apakah Anda ingin menggunakan registry publik atau pribadi untuk komponen Google Distributed Cloud.Lihat terlebih dahulu kolom osImageType, dan tentukan jenis sistem operasi yang ingin Anda jalankan di node cluster admin.
Jika organisasi Anda mewajibkan traffic keluar melewati server proxy, pastikan untuk memasukkan dalam daftar yang diizinkan API yang diperlukan dan alamat Artifact Registry.
Kumpulkan informasi yang Anda butuhkan untuk mengakses setiap instance vCenter Server. Anda memerlukan informasi ini untuk mengisi bagian
Secret
danVSphereInfraConfig.credentials.vCenters
dalam file konfigurasi infrastruktur vSphere. Lihat bagian berikut untuk mengetahui cara mendapatkan informasi yang diperlukan:
Isi file konfigurasi cluster admin Anda
Jika Anda menggunakan gkeadm
untuk membuat workstation admin, tindakan ini akan menghasilkan
file konfigurasi bernama admin-cluster.yaml
.
Jika Anda tidak menggunakan gkeadm
untuk membuat workstation admin, buat
admin-cluster.yaml
dengan menjalankan perintah ini di workstation admin:
gkectl create-config admin
File konfigurasi ini digunakan untuk membuat cluster admin Anda.
Pahami file konfigurasi dengan membaca dokumen file konfigurasi cluster admin. Sebaiknya buka dokumen ini di tab atau jendela terpisah, karena Anda akan merujuknya saat menyelesaikan langkah-langkah berikut.
name
Jika Anda ingin menentukan nama untuk cluster admin, isi kolom
name
.
bundlePath
Bundle adalah file terkompresi yang berisi komponen cluster. Fitur ini disertakan dengan workstation admin. Kolom ini sudah diisi untuk Anda.
enableAdvancedCluster
Tetapkan enableAdvancedCluster
ke true
. Tindakan ini mengaktifkan cluster lanjutan, yang diperlukan untuk menyiapkan domain topologi.
infraConfigFilePath
Tambahkan jalur lengkap ke
file konfigurasi infrastruktur vSphere
di kolom infraConfigFilePath
.
vCenter
Hapus seluruh bagian ini. Sebagai gantinya, Anda mengonfigurasi informasi vCenter Server di file konfigurasi infrastruktur vSphere.
network
Hapus berikut dari file konfigurasi:
- Seluruh bagian
network.hostConfig
. Informasi ini dikonfigurasi dalam file konfigurasi infrastruktur vSphere per domain topologi. - Kolom
network.vCenter.networkName
. Kolom ini dikonfigurasi di file konfigurasi infrastruktur vSphere per domain topologi. - Seluruh bagian
network.controlPlaneIPBlock
. Alamat IP untuk gateway, netmask, dan node bidang kontrol dikonfigurasi dalam file blok IP.
- Seluruh bagian
Setel
network.ipMode.ipBlockFilePath
ke jalur file blok IP.Tetapkan
network.ipMode.type
kestatic
.Kolom network.podCIDR dan network.serviceCIDR telah diisi sebelumnya dengan nilai yang dapat Anda biarkan tidak berubah, kecuali jika nilai tersebut berkonflik dengan alamat yang sudah digunakan di jaringan Anda. Kubernetes menggunakan rentang ini untuk menetapkan alamat IP ke Pod dan Service di cluster Anda.
loadBalancer
Tetapkan
loadBalancer.kind
ke"ManualLB"
, dan hapus bagianmanualLB
.Sisihkan VIP untuk server Kubernetes API cluster admin Anda. Berikan VIP Anda sebagai nilai untuk
loadBalancer.vips.controlPlaneVIP
Untuk mengetahui informasi selengkapnya, lihat VIP di subnet cluster admin.
antiAffinityGroups
Tetapkan
antiAffinityGroups.enabled
ke false
.
Aturan anti-afinitas Distributed Resource Scheduler
(DRS) tidak didukung dengan domain topologi.
adminMaster
Jika Anda ingin menentukan CPU dan memori untuk node control plane cluster admin, isi kolom
cpus
danmemoryMB
di bagianadminMaster
.Cluster admin harus memiliki tiga node bidang kontrol. Tetapkan kolom
replicas
di bagianadminMaster
ke3
.Jika Anda ingin menentukan domain topologi tertentu untuk digunakan oleh node bidang kontrol, tambahkan nama domain topologi ke kolom
adminMaster.topologyDomains
. Jika Anda tidak menentukan nama di sini, Anda harus menetapkan nama divSphereInfraConfig.defaultTopologyDomain
dalam file konfigurasi infrastruktur vSphere.
proxy
Jika jaringan yang akan memiliki node cluster admin Anda berada di belakang server proxy, isi bagian
proxy
.
privateRegistry
Tentukan tempat Anda ingin menyimpan image container untuk komponen Google Distributed Cloud. Opsinya adalah:
Artifact Registry
Registry Docker pribadi Anda sendiri.
Jika Anda ingin menggunakan registry pribadi Anda sendiri, isi bagian
privateRegistry
.
componentAccessServiceAccountKeyPath
Google Distributed Cloud menggunakan akun layanan akses komponen Anda untuk mendownload komponen cluster dari Artifact Registry. Kolom ini menyimpan jalur file kunci JSON untuk akun layanan akses komponen Anda.
Kolom ini sudah diisi untuk Anda.
gkeConnect
Daftarkan cluster admin Anda
ke Google Cloud fleet dengan mengisi bagian
gkeConnect
. ID di gkeConnect.projectID
harus sama dengan ID yang ditetapkan di
stackdriver.projectID
dan cloudAuditLogging.projectID
. Jika ID project
tidak sama, pembuatan cluster akan gagal.
Anda dapat secara opsional menentukan region tempat layanan Connect dan fleet berjalan di gkeConnect.location
. Jika Anda tidak menyertakan kolom ini, cluster akan menggunakan instance global dari layanan ini.
Jika Anda menyertakan gkeConnect.location
, region yang Anda tentukan harus sama dengan region yang dikonfigurasi di cloudAuditLogging.clusterLocation
, stackdriver.clusterLocation
, dan gkeOnPremAPI.location
. Jika regionnya
tidak sama, pembuatan cluster akan gagal.
gkeOnPremAPI
Bagian ini menjelaskan cara mendaftarkan cluster ke GKE On-Prem API.
Alat command line gkectl
adalah satu-satunya
alat pengelolaan siklus proses cluster
yang tersedia untuk cluster yang menggunakan domain topologi. Meskipun konsol Google Cloud , Google Cloud CLI, dan Terraform tidak didukung untuk cluster yang menggunakan domain topologi, Anda dapat secara opsional mendaftarkan cluster di GKE On-Prem API saat cluster dibuat.
Jika GKE On-Prem API diaktifkan di project Anda, semua cluster dalam project tersebut akan otomatis didaftarkan ke GKE On-Prem API di region yang dikonfigurasi di stackdriver.clusterLocation
. Google Cloud Region gkeOnPremAPI.location
harus sama dengan region yang ditentukan dalam cloudAuditLogging.clusterLocation
, gkeConnect.location
, dan stackdriver.clusterLocation
. Jika region tidak
sama, pembuatan cluster akan gagal.
Jika Anda ingin mendaftarkan semua cluster dalam project di GKE On-Prem API, pastikan untuk melakukan langkah-langkah di bagian Sebelum memulai untuk mengaktifkan dan menggunakan GKE On-Prem API dalam project.
Jika Anda tidak ingin mendaftarkan cluster di GKE On-Prem API, sertakan bagian ini dan tetapkan
gkeOnPremAPI.enabled
kefalse
. Jika Anda tidak ingin mendaftarkan cluster apa pun dalam project, nonaktifkangkeonprem.googleapis.com
(nama layanan untuk GKE On-Prem API) dalam project. Untuk mengetahui petunjuknya, lihat Menonaktifkan layanan.
stackdriver
Isi bagian
stackdriver
untuk mengaktifkan
Cloud Logging dan Cloud Monitoring
untuk cluster Anda.
Perhatikan persyaratan berikut:
ID di
stackdriver.projectID
harus sama dengan ID digkeConnect.projectID
dancloudAuditLogging.projectID
.Region Google Cloud yang ditetapkan di
stackdriver.clusterLocation
harus sama dengan region yang ditetapkan dicloudAuditLogging.clusterLocation
dangkeConnect.location
. Selain itu, jikagkeOnPremAPI.enabled
adalahtrue
, region yang sama harus ditetapkan digkeOnPremAPI.location
.
Jika project ID dan region tidak sama, pembuatan cluster akan gagal.
cloudAuditLogging
Jika Anda ingin mengintegrasikan log audit dari server Kubernetes API cluster Anda dengan Cloud Audit Logs, isi bagian
cloudAuditLogging
.
Perhatikan persyaratan berikut untuk cluster baru:
Karena
enableAdvancedCluster
ditetapkan ketrue
, Anda harus menentukan jalur yang sama dicloudAuditLogging.serviceAccountKeyPath
danstackdriver.serviceAccountKeyPath
.ID di
cloudAuditLogging.projectID
harus sama dengan ID digkeConnect.projectID
danstackdriver.projectID
.Region Google Cloud yang ditetapkan di
cloudAuditLogging.clusterLocation
harus sama dengan region yang ditetapkan distackdriver.clusterLocation
dangkeConnect.location
(jika kolom disertakan dalam file konfigurasi Anda). Selain itu, jikagkeOnPremAPI.enabled
adalahtrue
, region yang sama harus ditetapkan digkeOnPremAPI.location
.
Jika project ID dan region tidak sama, pembuatan cluster akan gagal.
clusterBackup
Hapus bagian ini. Mencadangkan cluster admin ke datastore vSphere tidak didukung.
autoRepair
Jika Anda ingin
mengaktifkan perbaikan node otomatis
untuk cluster admin, tetapkan
autoRepair.enabled
ke true
.
secretsEncryption
Karena enableAdvancedCluster
disetel ke true
, hapus bagian ini.
osImageType
Tetapkan
osImageType
.
ke ubuntu_cgroupv2
dan ubuntu_containerd
.
preparedSecrets
Hapus kolom preparedSecrets
.
Kredensial yang disiapkan
tidak didukung saat domain topologi diaktifkan.
Contoh file konfigurasi yang telah diisi
Berikut adalah contoh file konfigurasi cluster admin yang telah diisi. Konfigurasi mengaktifkan beberapa fitur yang tersedia, tetapi tidak semuanya.
vc-01-admin-cluster.yaml
apiVersion: v1 kind: AdminCluster name: "gke-admin-01" bundlePath: "/var/lib/gke/bundles/gke-onprem-vsphere-1.31.0-gke.1-full.tgz" enableAdvancedCluster: true infraConfigFilePath: "/my-config-folder/vsphere-infrastructure-config.yaml" network: serviceCIDR: "10.96.232.0/24" podCIDR: "192.168.0.0/16" ipMode: type: "static" ipBlockFilePath: "/my-config-folder/admin-cluster-ipblock.yaml" loadBalancer: vips: controlPlaneVIP: "172.16.20.59" kind: "ManualLB" antiAffinityGroups: enabled: false adminMaster: cpus: 4 memoryMB: 16384 replicas: 3 topologyDomains: "admin-cluster-domain" componentAccessServiceAccountKeyPath: "sa-key.json" gkeConnect: projectID: "my-project-123" registerServiceAccountKeyPath: "connect-register-sa-2203040617.json" stackdriver: projectID: "my-project-123" clusterLocation: "us-central1" enableVPC: false serviceAccountKeyPath: "log-mon-sa-2203040617.json" disableVsphereResourceMetrics: false autoRepair: enabled: true osImageType: "ubuntu_containerd"
Isi file konfigurasi infrastruktur vSphere Anda
Salin template untuk
file konfigurasi infrastruktur vSphere
ke file di direktori yang Anda tentukan di kolom infraConfigFilePath
dalam file konfigurasi cluster admin. Hanya ada satu file konfigurasi infrastruktur vSphere untuk cluster admin dan semua cluster pengguna terkelola.
Secret
Isi bagian Secret
di file konfigurasi infrastruktur vSphere. Bagian ini menjelaskan
Secret kredensial vSphere yang menyimpan kredensial setiap vCenter Server.
VSphereInfraConfig.name
Isi kolom VSphereInfraConfig,name
.
VSphereInfraConfig.credentials.vCenters
Untuk setiap Secret
, tambahkan bagian
VSphereInfraConfig.credentials.vCenters
yang sesuai.
VSphereInfraConfig,topologyDomains
Isi bagian
VSphereInfraConfig.topologyDomains
untuk
menentukan domain topologi.
Isi file blok IP Anda
Salin template untuk
file blok IP ke file di
direktori yang Anda tentukan di kolom network.ipMode.ipBlockFilePath
dalam file konfigurasi cluster admin. Tambahkan alamat IP untuk gateway,
netmask, dan tiga node bidang kontrol. Untuk setiap alamat IP node control plane, tambahkan isControlPlane: true
seperti yang ditunjukkan dalam
contoh untuk domain topologi.
Mendapatkan image OS
Download paket Google Distributed Cloud normal ke workstation admin:
gcloud storage cp gs://gke-on-prem-release/gke-onprem-bundle/VERSION/gke-onprem-vsphere-VERSION.tgz /var/lib/gke/bundles/gke-onprem-vsphere-VERSION.tgz
Ganti
VERSION
dengan versi Google Distributed Cloud yang ingin Anda instal.Perintah ini akan mendownload paket normal. Jangan mendownload paket lengkap karena tidak didukung dengan cluster lanjutan.
Jalankan
gkectl prepare
untuk menginisialisasi lingkungan vSphere Anda:gkectl prepare --config ADMIN_CLUSTER_CONFIG
Ganti
ADMIN_CLUSTER_CONFIG
dengan jalur konfigurasi cluster admin.Perintah
gkectl prepare
melakukan tugas persiapan berikut:Mengimpor image OS ke vSphere dan menandainya sebagai template VM.
Jika Anda menggunakan registry Docker pribadi, kirim image container ke registry Anda.
Secara opsional, memvalidasi pengesahan build image container, sehingga memverifikasi bahwa image dibangun dan ditandatangani oleh Google serta siap untuk di-deploy.
Buat cluster admin
Buat cluster admin:
gkectl create admin --configADMIN_CLUSTER_CONFIG
Melanjutkan pembuatan cluster admin setelah terjadi kegagalan
Jika pembuatan cluster admin gagal atau dibatalkan, Anda dapat menjalankan perintah create
lagi:
gkectl create admin --config ADMIN_CLUSTER_CONFIG
Cari file kubeconfig cluster admin
Perintah gkectl create admin
akan membuat file kubeconfig bernama kubeconfig
di direktori saat ini. Anda akan memerlukan file kubeconfig ini nanti untuk berinteraksi dengan cluster admin.
File kubeconfig berisi nama cluster admin Anda. Untuk melihat nama cluster, Anda dapat menjalankan:
kubectl config get-clusters --kubeconfig ADMIN_CLUSTER_KUBECONFIG
Output menampilkan nama cluster. Contoh:
NAME gke-admin-tqk8x
Jika ingin, Anda dapat mengubah nama dan lokasi file kubeconfig.
Pastikan cluster admin Anda berjalan
Pastikan cluster admin Anda berjalan:
kubectl get nodes --kubeconfig ADMIN_CLUSTER_KUBECONFIG
Ganti ADMIN_CLUSTER_KUBECONFIG dengan jalur file kubeconfig cluster admin Anda.
Output menampilkan node cluster admin. Contoh:
admin-cp-vm-1 Ready control-plane,master ... admin-cp-vm-2 Ready control-plane,master ... admin-cp-vm-3 Ready control-plane,master ...
Konfigurasi PodTemplate
Label topologi diisi ke label node dalam domain topologi.
Kecuali jika penyiapan domain topologi Anda menggunakan batasan default,
"topology.kubernetes.io/zone"
sebagai kunci topologi, Anda harus mengonfigurasi kunci topologi di template
pod Deployment, StatefulSet, atau ReplicaSet, sebagaimana berlaku.
Misalnya, Anda menentukan kunci di label topologi sebagai
"topology.examplepetstore.com/zone"
. Di PodTemplate
, Anda menentukan kunci
sebagai nilai untuk kolom topologySpreadConstraints.topologyKey
. Hal ini memungkinkan penjadwal Kubernetes mendistribusikan Pod di seluruh domain topologi untuk memastikan ketersediaan tinggi dan mencegah konsentrasi berlebih di satu area jika terjadi kegagalan.
Untuk mengetahui informasi selengkapnya tentang cara mengonfigurasi topologySpreadConstraints
, lihat
Batasan Penyebaran Topologi Pod
dalam dokumentasi Kubernetes.
Mencadangkan file
Sebaiknya cadangkan file kubeconfig cluster admin Anda. Artinya, salin file kubeconfig dari workstation admin Anda ke lokasi lain. Kemudian, jika Anda kehilangan akses ke workstation admin, atau jika file kubeconfig di workstation admin Anda terhapus secara tidak sengaja, Anda masih memiliki akses ke cluster admin.
Sebaiknya Anda juga mencadangkan kunci SSH pribadi untuk cluster admin Anda. Kemudian, jika Anda kehilangan akses ke cluster admin, Anda masih dapat menggunakan SSH untuk terhubung ke node cluster admin. Dengan begitu, Anda dapat memecahkan masalah dan menyelidiki masalah konektivitas ke cluster admin.
Ekstrak kunci SSH dari cluster admin ke file bernama
admin-cluster-ssh-key
:
kubectl --kubeconfigADMIN_CLUSTER_KUBECONFIG get secrets -n kube-system sshkeys \ -o jsonpath='{.data.vsphere_tmp}' | base64 -d > admin-cluster-ssh-key
Sekarang Anda dapat mencadangkan admin-cluster-ssh-key
ke lokasi lain pilihan Anda.
Pemecahan masalah
Lihat Memecahkan masalah pembuatan dan upgrade cluster.
Langkah berikutnya
Membuat cluster pengguna untuk digunakan di domain topologi