Tutorial ini menunjukkan cara menyesuaikan node cluster Google Kubernetes Engine (GKE) menggunakan DaemonSets. DaemonSet memastikan bahwa semua node (atau yang dipilih) menjalankan salinan Pod. Dengan pendekatan ini, Anda dapat menggunakan alat yang sama untuk mengatur workload yang Anda gunakan untuk mengubah node GKE.
Jika alat dan sistem yang Anda gunakan untuk menginisialisasi cluster Anda berbeda dengan alat dan sistem yang Anda gunakan untuk menjalankan workload, Anda akan meningkatkan upaya yang diperlukan untuk mengelola lingkungan Anda. Misalnya, jika Anda menggunakan alat manajemen konfigurasi untuk melakukan inisialisasi node cluster, Anda mengandalkan prosedur yang berada di luar lingkungan runtime tempat sisa workload Anda berjalan.
Tujuan tutorial ini adalah untuk membantu administrator sistem, engineer sistem, atau operator infrastruktur menyederhanakan inisialisasi cluster Kubernetes.
Untuk tutorial ini, Anda harus memahami alat-alat berikut:
Dalam tutorial ini, Anda akan mempelajari cara
menggunakan label dan pemilih Kubernetes
untuk memilih prosedur inisialisasi yang akan dijalankan berdasarkan label yang diterapkan
ke suatu node. Pada langkah-langkah ini, Anda akan men-deploy DaemonSet agar hanya berjalan pada node
dengan label default-init
yang diterapkan. Namun, untuk menunjukkan
fleksibilitas mekanisme ini, Anda dapat membuat node pool lain dan menerapkan
label alternative-init
ke node dalam pool baru ini. Di cluster, Anda
kemudian dapat men-deploy DaemonSet lain yang dikonfigurasi agar berjalan hanya pada node yang
memiliki label alternative-init
.
Selain itu, Anda dapat menjalankan beberapa prosedur inisialisasi pada setiap node, bukan hanya satu saja. Anda dapat memanfaatkan mekanisme ini untuk menyusun prosedur inisialisasi dengan lebih baik, dan memisahkan masalah setiap proses dengan jelas.
Sebagai contoh, dalam tutorial ini, prosedur inisialisasi melakukan tindakan berikut pada setiap node yang diberi label dengan label default-init
:
- Memasang disk tambahan ke node.
- Menginstal serangkaian paket dan library menggunakan pengelola paket sistem operasi node.
- Memuat set modul kernel Linux.
Tujuan
Dalam tutorial ini, Anda akan melakukan beberapa hal berikut:
- Menyediakan dan mengonfigurasi cluster GKE.
- Menyiapkan deskripsi DaemonSet untuk melakukan inisialisasi node dalam cluster.
- Men-deploy DaemonSet di cluster.
- Verifikasi bahwa node cluster telah diinisialisasi.
Biaya
Dalam dokumen ini, Anda menggunakan komponen Google Cloud yang dapat ditagih berikut:
Untuk membuat perkiraan biaya berdasarkan proyeksi penggunaan Anda,
gunakan kalkulator harga.
Setelah menyelesaikan tugas yang dijelaskan dalam dokumen ini, Anda dapat menghindari penagihan berkelanjutan dengan menghapus resource yang Anda buat. Untuk mengetahui informasi selengkapnya, lihat Pembersihan.
Sebelum memulai
- Login ke akun Google Cloud Anda. Jika Anda baru menggunakan Google Cloud, buat akun untuk mengevaluasi performa produk kami dalam skenario dunia nyata. Pelanggan baru juga mendapatkan kredit gratis senilai $300 untuk menjalankan, menguji, dan men-deploy workload.
-
Di konsol Google Cloud, pada halaman pemilih project, pilih atau buat project Google Cloud.
-
Pastikan penagihan telah diaktifkan untuk project Google Cloud Anda.
-
Di konsol Google Cloud, pada halaman pemilih project, pilih atau buat project Google Cloud.
-
Pastikan penagihan telah diaktifkan untuk project Google Cloud Anda.
Melakukan bootstrap pada lingkungan
Di bagian ini, Anda akan melakukan hal berikut:
- Mengaktifkan Cloud API yang diperlukan.
- Menyediakan akun layanan dengan hak istimewa terbatas untuk node di cluster GKE.
- Menyiapkan cluster GKE.
- Memberikan hak istimewa administrasi cluster pengguna.
Aktifkan Cloud API
Buka Cloud Shell.
Pilih project Google Cloud:
gcloud config set project project-id
Ganti
project-id
dengan ID project Google Cloud yang Anda buat atau pilih untuk tutorial ini.Aktifkan Google Kubernetes Engine API:
gcloud services enable container.googleapis.com
Menyediakan akun layanan untuk mengelola cluster GKE
Di bagian ini, Anda akan membuat akun layanan yang terkait dengan node dalam cluster. Dalam tutorial ini, node GKE menggunakan akun layanan ini, bukan akun layanan default. Sebagai praktik terbaik, cukup berikan akun layanan peran dan izin akses yang diperlukan untuk menjalankan aplikasi.
Peran yang diperlukan untuk akun layanan adalah sebagai berikut:
- Peran Monitoring Viewer (
roles/monitoring.viewer
). Peran ini memberikan akses hanya baca ke konsol Cloud Monitoring dan API. - Peran Penulis Metrik Pemantauan (
roles/monitoring.metricWriter
). Peran ini mengizinkan penulisan data pemantauan. - Peran Penulis Log (
roles/logging.logWriter
). Peran ini memberikan izin yang cukup untuk menulis log. - Peran Pengguna Akun layanan (
roles/iam.serviceAccountUser
). Peran ini memberikan akses ke akun layanan dalam sebuah project. Dalam tutorial ini, prosedur inisialisasi meniru identitas akun layanan untuk menjalankan operasi dengan hak istimewa. - Peran Admin Compute (
roles/compute.admin
). Peran ini memberikan kontrol penuh atas semua resource Compute Engine. Dalam tutorial ini, akun layanan memerlukan peran ini untuk memasang disk tambahan ke node cluster.
Untuk menyediakan akun layanan, ikuti langkah-langkah berikut:
Di Cloud Shell, lakukan inisialisasi variabel lingkungan yang menyimpan nama akun layanan:
GKE_SERVICE_ACCOUNT_NAME=ds-init-tutorial-gke
Membuat akun layanan
gcloud iam service-accounts create "$GKE_SERVICE_ACCOUNT_NAME" \ --display-name="$GKE_SERVICE_ACCOUNT_NAME"
Lakukan inisialisasi variabel lingkungan yang menyimpan nama akun email akun layanan:
GKE_SERVICE_ACCOUNT_EMAIL="$(gcloud iam service-accounts list \ --format='value(email)' \ --filter=displayName:"$GKE_SERVICE_ACCOUNT_NAME")"
Ikat peran Identity and Access Management (IAM) ke akun layanan:
gcloud projects add-iam-policy-binding \ "$(gcloud config get-value project 2> /dev/null)" \ --member serviceAccount:"$GKE_SERVICE_ACCOUNT_EMAIL" \ --role roles/compute.admin gcloud projects add-iam-policy-binding \ "$(gcloud config get-value project 2> /dev/null)" \ --member serviceAccount:"$GKE_SERVICE_ACCOUNT_EMAIL" \ --role roles/monitoring.viewer gcloud projects add-iam-policy-binding \ "$(gcloud config get-value project 2> /dev/null)" \ --member serviceAccount:"$GKE_SERVICE_ACCOUNT_EMAIL" \ --role roles/monitoring.metricWriter gcloud projects add-iam-policy-binding \ "$(gcloud config get-value project 2> /dev/null)" \ --member serviceAccount:"$GKE_SERVICE_ACCOUNT_EMAIL" \ --role roles/logging.logWriter gcloud projects add-iam-policy-binding \ "$(gcloud config get-value project 2> /dev/null)" \ --member serviceAccount:"$GKE_SERVICE_ACCOUNT_EMAIL" \ --role roles/iam.serviceAccountUser
Menyiapkan cluster GKE
Di bagian ini, Anda akan meluncurkan cluster GKE, memberikan izin, dan menyelesaikan konfigurasi cluster.
Untuk tutorial ini, cluster dengan jumlah node kecil
tujuan umum
yang relatif rendah sudah cukup untuk mendemonstrasikan konsep tutorial ini. Anda membuat
cluster dengan
satu node pool
(yang default). Selanjutnya, Anda memberi label semua node di
node pool default dengan label default-init
.
Di Cloud Shell, buat dan luncurkan cluster GKE regional:
gcloud container clusters create ds-init-tutorial \ --enable-ip-alias \ --image-type=ubuntu_containerd \ --machine-type=n1-standard-2 \ --metadata disable-legacy-endpoints=true \ --node-labels=app=default-init \ --node-locations us-central1-a,us-central1-b,us-central1-c \ --no-enable-basic-auth \ --no-issue-client-certificate \ --num-nodes=1 \ --region us-central1 \ --service-account="$GKE_SERVICE_ACCOUNT_EMAIL"
Men-deploy DaemonSet
Di bagian ini, Anda akan melakukan hal berikut:
- Membuat ConfigMap yang menyimpan prosedur inisialisasi.
- Men-deploy DaemonSet yang menjadwalkan dan menjalankan prosedur inisialisasi.
DaemonSet melakukan hal berikut:
- Mengonfigurasi volume yang membuat konten ConfigMap tersedia untuk container yang ditangani DaemonSet.
- Mengonfigurasi volume untuk area sistem file dengan hak istimewa dari node cluster yang mendasarinya. Area ini memungkinkan container yang dijadwalkan DaemonSet berinteraksi langsung dengan node yang menjalankannya.
- Menjadwalkan dan menjalankan container init yang menjalankan prosedur inisialisasi, kemudian dihentikan setelah selesai.
- Menjadwalkan dan menjalankan container yang tetap tidak ada aktivitas dan tidak menggunakan resource.
Container tanpa ada aktivitas memastikan bahwa node hanya diinisialisasi sekali. DaemonSets didesain agar semua node yang memenuhi syarat menjalankan salinan Pod. Jika Anda menggunakan container reguler, container tersebut akan menjalankan prosedur inisialisasi, lalu dihentikan setelah selesai. Secara desain, DaemonSet menjadwalkan ulang Pod. Untuk menghindari "penjadwalan ulang berkelanjutan", DaemonSet terlebih dahulu menjalankan prosedur inisialisasi dalam container init, lalu membiarkan container tetap berjalan.
Prosedur inisialisasi berikut berisi operasi dengan hak istimewa dan
tidak istimewa. Dengan menggunakan chroot
, Anda dapat menjalankan
perintah seolah-olah sedang mengeksekusinya langsung di node, bukan hanya di dalam container.
Sebaiknya tinjau setiap prosedur inisialisasi dengan cermat karena prosedur ini dapat mengubah status node cluster Anda. Hanya sekelompok kecil individu yang berhak memodifikasi prosedur tersebut, karena prosedur tersebut dapat sangat memengaruhi ketersediaan dan keamanan cluster Anda.
Untuk men-deploy ConfigMap dan DaemonSet, lakukan hal berikut:
Di Cloud Shell, ubah direktori kerja ke direktori
$HOME
:cd "$HOME"
Buat clone repositori Git yang berisi skrip dan file manifes untuk men-deploy dan mengonfigurasi prosedur inisialisasi:
git clone https://github.com/GoogleCloudPlatform/solutions-gke-init-daemonsets-tutorial
Ubah direktori kerja ke direktori repositori yang baru saja di-clone:
cd "$HOME"/solutions-gke-init-daemonsets-tutorial
Buat ConfigMap untuk menyimpan skrip inisialisasi node:
kubectl apply -f cm-entrypoint.yaml
Deploy DaemonSet:
kubectl apply -f daemon-set.yaml
Verifikasi bahwa inisialisasi node selesai:
kubectl get ds --watch
Tunggu hingga DaemonSet dilaporkan sebagai siap dan terbaru, seperti yang ditunjukkan oleh output yang mirip dengan berikut ini:
NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE node-initializer 3 3 3 3 3 <none> 2h
Memvalidasi dan memverifikasi prosedur inisialisasi
Setelah setiap node cluster yang ditandai dengan label default-init
mengeksekusi
prosedur inisialisasi, Anda dapat memverifikasi hasilnya.
Untuk setiap node, prosedur verifikasi akan memeriksa hal-hal berikut:
- Disk tambahan terpasang dan siap digunakan.
- Pengelola paket sistem operasi node menginstal paket dan library.
- Modul kernel telah dimuat.
Jalankan prosedur verifikasi:
Jalankan skrip verifikasi di Cloud Shell:
kubectl get nodes -o=jsonpath='{range .items[?(@.metadata.labels.app=="default-init")]}{.metadata.name}{" "}{.metadata.labels.failure-domain\.beta\.kubernetes\.io/zone}{"\n"}{end}' | while IFS= read -r line ; do ./verify-init.sh $line < /dev/null; done
Tunggu skrip berjalan dan pastikan setiap node telah diinisialisasi dengan benar, seperti yang ditunjukkan oleh output seperti berikut:
Verifying gke-ds-init-tutorial-default-pool-5464b7e3-nzjm (us-central1-c) configuration Disk configured successfully on gke-ds-init-tutorial-default-pool-5464b7e3-nzjm (us-central1-c) Packages installed successfully in gke-ds-init-tutorial-default-pool-5464b7e3-nzjm (us-central1-c) Kernel modules loaded successfully on gke-ds-init-tutorial-default-pool-5464b7e3-nzjm (us-central1-c) Verifying gke-ds-init-tutorial-default-pool-65baf745-0gwt (us-central1-a) configuration Disk configured successfully on gke-ds-init-tutorial-default-pool-65baf745-0gwt (us-central1-a) Packages installed successfully in gke-ds-init-tutorial-default-pool-65baf745-0gwt (us-central1-a) Kernel modules loaded successfully on gke-ds-init-tutorial-default-pool-65baf745-0gwt (us-central1-a) Verifying gke-ds-init-tutorial-default-pool-6b125c50-3xvl (us-central1-b) configuration Disk configured successfully on gke-ds-init-tutorial-default-pool-6b125c50-3xvl (us-central1-b) Packages installed successfully in gke-ds-init-tutorial-default-pool-6b125c50-3xvl (us-central1-b) Kernel modules loaded successfully on gke-ds-init-tutorial-default-pool-6b125c50-3xvl (us-central1-b)
Pembersihan
Agar tidak menimbulkan biaya pada akun Google Cloud Anda untuk resource yang digunakan dalam tutorial ini, Anda dapat menghapus project yang dibuat untuk tutorial ini. Jika membuat project khusus untuk tutorial ini, Anda dapat menghapusnya sepenuhnya. Jika Anda menggunakan project yang sudah ada, tetapi tidak ingin menghapusnya, gunakan langkah-langkah berikut untuk membersihkan project.
Membersihkan project
Untuk membersihkan project tanpa menghapusnya, Anda harus menghapus resource yang dibuat dalam tutorial ini.
Di Cloud Shell, hapus cluster GKE:
gcloud container clusters delete ds-init-tutorial --quiet --region us-central1
Hapus disk tambahan yang Anda buat sebagai bagian dari contoh prosedur inisialisasi ini:
gcloud compute disks list --filter="name:additional" --format="csv[no-heading](name,zone)" | while IFS= read -r line ; do DISK_NAME="$(echo $line | cut -d',' -f1)"; ZONE="$(echo $line | cut -d',' -f2)"; gcloud compute disks delete "$DISK_NAME" --quiet --zone "$ZONE" < /dev/null; done
Hapus akun layanan:
gcloud iam service-accounts delete "$GKE_SERVICE_ACCOUNT_EMAIL" --quiet
Hapus direktori repositori yang di-clone:
rm -rf "$HOME"/solutions-gke-init-daemonsets-tutorial
Menghapus project
Cara termudah untuk menghilangkan penagihan adalah dengan menghapus project yang Anda buat untuk tutorial.
- Di konsol Google Cloud, buka halaman Manage resource.
- Pada daftar project, pilih project yang ingin Anda hapus, lalu klik Delete.
- Pada dialog, ketik project ID, lalu klik Shut down untuk menghapus project.
Langkah selanjutnya
- Baca tentang GKE.
- Implementasikan supply chain software yang aman.
- Pelajari cara memperkuat keamanan cluster GKE.
- Pelajari arsitektur referensi, diagram, dan praktik terbaik tentang Google Cloud. Lihat Cloud Architecture Center kami.