Tutorial ini menunjukkan cara mengonfigurasi Integrasi Aplikasi untuk menerima notifikasi cluster Google Kubernetes Engine (GKE) melalui email.
Anda membuat integrasi dengan pemicu Pub/Sub untuk memproses topik yang ada yang menerima notifikasi dari cluster GKE. Kemudian, Anda dapat menggunakan tugas Pemetaan Data dan Pengubah Data untuk mengubah pesan Pub/Sub dan membuat isi email teks biasa.
Tujuan
- Buat aplikasi Integrasi Aplikasi untuk menerima dan mengubah notifikasi eksternal dari GKE.
- Tulis tugas Kirim Email yang mengirimkan notifikasi Pub/Sub ke email.
Biaya
Dalam dokumen ini, Anda akan menggunakan komponen Google Cloudyang 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
- 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 GKE, Application Integration and Pub/Sub 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 GKE, Application Integration and Pub/Sub APIs.
- Aktifkan penerimaan notifikasi cluster GKE melalui Pub/Sub.
- Jika Anda menggunakan Integrasi Aplikasi di project untuk pertama kalinya, pastikan Anda telah menyiapkan Integrasi Aplikasi.
-
Pub/Sub Editor (
roles/pubsub.editor
) -
Editor Application Integration (
roles/integrations.editor
)
Peran yang diperlukan
Untuk memastikan bahwa service-PROJECT_NUMBER@gcp-sa-integrations.iam.gserviceaccount.com memiliki izin yang diperlukan untuk menyiapkan notifikasi email untuk notifikasi cluster, minta administrator Anda untuk memberikan peran IAM berikut kepada service-PROJECT_NUMBER@gcp-sa-integrations.iam.gserviceaccount.com di project Anda:iam.gserviceaccount.com
Menyiapkan notifikasi cluster untuk cluster GKE Anda
Untuk menggunakan Pub/Sub guna menerima notifikasi tentang cluster GKE Anda, ikuti Menerima notifikasi cluster melalui Pub/Sub.
Buat integrasi baru
Untuk membuat integrasi baru, lakukan langkah-langkah berikut:
Buka halaman Application Integration di konsol Google Cloud .
Di menu navigasi, klik Integrations. Halaman Integrations akan muncul.
Klik Buat integrasi.
Di Integration name, masukkan nama untuk integrasi yang Anda buat.
Jika Anda mengaktifkan beberapa wilayah, opsi drop-down akan ditampilkan agar Anda dapat memilih wilayah untuk integrasi. Jika hanya satu wilayah yang diaktifkan, wilayah tersebut akan menjadi default dan drop-down tidak akan ditampilkan.
Catatan: Drop-down Regions hanya mencantumkan region yang disediakan di Google Cloud project Anda. Untuk menyediakan region baru, Klik Enable Region yang ditampilkan di bagian bawah kotak.
Klik Buat untuk membuka editor integrasi.
Menambahkan dan mengonfigurasi pemicu Pub/Sub
Untuk menambahkan pemicu Pub/Sub ke integrasi, ikuti langkah-langkah berikut:
Di editor integrasi, pilih Pemicu untuk menampilkan daftar pemicu yang tersedia.
Klik dan tempatkan elemen pemicu Pub/Sub ke desainer.
Klik elemen Pemicu Pub/Sub di editor integrasi untuk melihat panel konfigurasi pemicu.
Tentukan topik yang harus didengarkan oleh pemicu di kolom Pub/Sub topic dalam format berikut:
projects/PROJECT_ID/topics/TOPIC_ID
Ganti kode berikut:
PROJECT_ID
: Google Cloud project tempat topik Anda dibuat.TOPIC_ID
: ID topik Pub/Sub yang Anda buat di Siapkan lingkungan Anda.Misalnya, jika project Anda bernama
my-project
dan Anda memberi nama topikgke-notifications
, masukkan:projects/my-project/topics/gke-notifications
Untuk melihat semua topik yang tersedia di project Google Cloud Anda, lihat kolom Nama topik di Topik. Panel konfigurasi pemicu Pub/Sub akan otomatis mengisi kolom Output Pemicu dengan variabel untuk menyimpan pesan Pub/Sub.
Menambahkan dan mengonfigurasi tugas Pemetaan Data
Tugas Pemetaan Data membantu mengekstrak variabel yang relevan dari notifikasi Pub/Sub. Fungsi ini mengambil file JSON pesan Pub/Sub sebagai input dan mengekstrak variabel sebagai output.
Untuk mengonfigurasi tugas Pemetaan Data:
Pilih Tugas untuk menampilkan daftar tugas yang tersedia.
Klik dan tempatkan elemen Pemetaan Data di editor integrasi.
Klik tugas Pemetaan Data di perancang untuk membuka panel konfigurasi tugas.
Untuk menambahkan koneksi edge dari pemicu Pub/Sub ke Pemetaan Data, tahan kursor di atas titik kontrol pada pemicu Pub/Sub, lalu tarik garis ke titik kontrol pada tugas Pemetaan Data. Edge menunjukkan alur kontrol dari pemicu Pub/Sub ke tugas Pemetaan Data.
Klik Buka Editor Pemetaan Data. Editor Pemetaan Data memungkinkan Anda memetakan variabel input ke variabel output yang dipilih, menggunakan fungsi transformasi yang tersedia. Output kemudian tersedia sebagai variabel untuk tugas atau pemicu integrasi lainnya. Untuk mengetahui informasi selengkapnya tentang variabel di Integrasi Aplikasi, lihat Variabel.
Untuk tutorial ini, ikuti langkah-langkah berikut untuk membuat pemetaan menggunakan
CloudPubSubMessage
sebagai input:- Perluas variabel JSON
CloudPubSubMessage
dalam daftar Variables dan tarik variabelCloudPubSubMessage.data
ke baris Input pertama. - Untuk membuat variabel output baru yang menyimpan nilai data yang diubah,
klik baris pertama di kolom Output. Kemudian, lakukan hal berikut:
- Di kolom Name, masukkan
message_data
. - Dari daftar Variable Type, pilih Output from integration.
- Dari daftar Jenis Data, pilih String.
- Klik Buat. Variabel
message_data
muncul di Output.
- Di kolom Name, masukkan
- Tarik variabel
CloudPubSubMessage.attributes
dari daftar Variabel ke baris kedua di kolom Input. Klik baris kedua di kolom Output untuk membuat variabel output baru guna menyimpan nilai payload JSON dengan atribut cluster. Lengkapi kolom berikut:
- Di kolom Name, masukkan
attributes
. - Dari daftar Jenis Variabel, pilih Tidak Ada.
- Dari daftar Jenis Data, pilih JSON.
Pilih Masukkan skema JSON dari opsi skema JSON, lalu tempelkan payload berikut:
{ "$schema": "http://json-schema.org/draft-07/schema#", "type": "object", "properties": { "cluster_name": { "type": "string" }, "payload": { "type": "string" }, "project_id": { "type&qu
ot;: "string" }, "cluster_location": { "type": "string" }, "type_url": { "type": "string" } } }Klik Buat. Variabel
attributes
muncul di Output. Pastikan variabel atribut terlihat mirip dengan berikut ini:
- Di kolom Name, masukkan
Klik baris ketiga di kolom Input, lalu pilih
attributes.cluster_name
dari panel Variabel. Anda mungkin perlu mulai mengetik attributes untuk melihat semua 5 atribut yang ditentukan dari skema yang dimasukkan pada langkah sebelumnya.Klik baris yang sesuai dari kolom Output untuk membuat variabel output baru yang akan menyimpan nilai atribut nama cluster. Lengkapi kolom berikut:
- Di kolom Name, masukkan
cluster_name
. - Dari daftar Variable Type, pilih Output from integration.
- Dari daftar Jenis Data, pilih String.
- Klik Buat. Variabel
cluster_name
muncul di Output.
- Di kolom Name, masukkan
Ulangi langkah e dan f untuk
project_id
,cluster_location
,type_url
, danpayload
.Tutup Editor Pemetaan Data setelah pemetaan Anda selesai. Setiap perubahan akan disimpan otomatis.
- Perluas variabel JSON
Menambahkan dan mengonfigurasi tugas Transformer Data (Skrip)
Tugas Data Transformer mengambil variabel yang diekstrak dari tugas Pemetaan Data sebagai input dan mengubahnya menjadi isi pesan untuk penggunaan pengguna akhir.
Untuk mengonfigurasi tugas Data Transformer:
- Pilih Tugas untuk menampilkan daftar tugas yang tersedia.
- Klik dan tempatkan elemen Data Transformer (Script) di editor integrasi.
- Klik tugas Data Transformer di perancang untuk membuka panel konfigurasi tugas.
- Untuk menambahkan koneksi edge dari tugas Pemetaan Data ke tugas Pengubah Data, tahan pointer di atas titik kontrol pada Pemetaan Data, lalu tarik garis ke titik kontrol pada tugas Pengubah Data. Edge menunjukkan aliran kontrol dari tugas Pemetaan Data ke tugas Transformer Data.
Klik Buka Editor Pengubah Data. Editor Transformer Data memungkinkan Anda menulis, mengedit, dan mengevaluasi template Jsonnet kustom untuk melakukan pemetaan data dalam integrasi Anda. Output kemudian tersedia sebagai variabel untuk tugas atau pemicu integrasi lainnya. Untuk mengetahui detail selengkapnya tentang tugas transformer ini, lihat Tugas Transformer Data. Untuk panduan memulai ini, ikuti langkah-langkah berikut untuk membuat skrip:
Klik
Buat di panel kiri Variabel. Tindakan ini akan membuka panel Buat variabel di sisi kanan. Lengkapi kolom berikut:- Nama: Masukkan
full_message
. - Pilih
Output from integration
di kotak drop-down Variable Type. - Pilih
String
di kotak drop-down Jenis Data. - Klik Buat untuk membuat variabel dan menutup panel. Variabel
full_message
baru akan muncul di daftar Variabel.
- Nama: Masukkan
Pilih Skrip.
Gunakan contoh skrip berikut sebagai template untuk isi pesan saat notifikasi dikirim dari cluster Anda:
local message_data = std.extVar("message_data"); local cluster_name = std.extVar("cluster_name"); local project_id = std.extVar("project_id"); local cluster_location = std.extVar("cluster_location"); local type_url = std.extVar("type_url"); local payload = std.extVar("payload"); {full_message: "Project ID: " + project_id + "\n" + "Cluster Name: " + cluster_name + "\n" + "Location: " + cluster_location + "\n" + "Event Type: " + type_url
+ "\n" + "Message: " + message_data + "\n" + "Payload: " + std.manifestJson(std.parseJson(payload))}Tutup Editor Pemetaan Data setelah pemetaan Anda selesai. Setiap perubahan akan disimpan otomatis.
Menambahkan dan mengonfigurasi tugas Kirim Email
Untuk mengonfigurasi tugas Kirim Email:
- Pilih Tugas di editor integrasi untuk menampilkan daftar tugas yang tersedia.
- Klik dan tempatkan elemen Kirim Email di editor integrasi.
- Untuk menambahkan koneksi edge dari tugas Data Transformer ke tugas Send email, tahan pointer di titik kontrol pada tugas Data Transformer, lalu tarik garis ke titik kontrol pada tugas Send email. Edge menunjukkan aliran kontrol dari tugas Data Transformer ke tugas Kirim email.
- Klik elemen Send Email di perancang untuk membuka panel konfigurasi
tugas. Tetapkan properti berikut:
- Kepada Penerima: Masukkan alamat email. Anda akan menggunakan email ini untuk mengonfirmasi keberhasilan penyelesaian integrasi.
- Subjek: Masukkan
GKE Notifications
. - Isi dalam Teks Biasa: Pilih variabel
full_message
yang dibuat sebelumnya di tugas Pengubah Data. - Opsi lainnya dapat dibiarkan dalam konfigurasi default.
Perubahan Anda pada properti akan disimpan secara otomatis dan kanvas Anda akan terlihat mirip dengan berikut ini:
Menguji integrasi
Untuk menguji integrasi baru, buka menu navigasi di bagian atas diagram Integrasi, lalu klik Uji. Panel akan terbuka di sisi kanan. Anda dapat menggunakan contoh pesan Pub/Sub berikut di bagian Tambahkan nilai json:
{
"data": "Node pool projects/my-project/locations/us-central1-c/clusters/cluster-1/nodePools/default-pool is upgrading to version 1.29.1-gke.1589017.",
"attributes": {
"cluster_location": "us-central1-c",
"cluster_name": "cluster-1",
"payload": "{\"resourceType\":\"NODE_POOL\",\"operation\":\"operation-upgrade\",\"operationStartTime\":\"2024-05-07T20:09:35.528855756Z\",\"currentVersion\":\"1.28.7-gke.1026000\",\"targetVersion\":\"1.29.1-gke.1589017\",\"resource\":\"proje
cts/my-project/locations/us-central1-c/clusters/cluster-1/nodePools/default-pool\"}",
"project_id": "my-project",
"type_url": "type.googleapis.com/google.container.v1beta1.UpgradeEvent"
}
}
Email akan dikirim ke alamat email yang telah Anda konfigurasi di tugas Send Email setelah mengklik tombol Test Integration.
Memublikasikan integrasi Anda
Setelah Anda berhasil menguji integrasi ini, klik Publikasikan agar integrasi Anda mulai memproses pesan.
Anda hanya dapat mengedit satu versi integrasi DRAFT
, dan hanya dapat mengeksekusi satu versi integrasi ACTIVE
. Jika Anda ingin mengedit integrasi, klik Aktifkan Pengeditan
di halaman perancang integrasi, lalu buat versi draf. Untuk mengetahui informasi selengkapnya, lihat Kunci pengeditan integrasi.
Pembersihan
Agar tidak perlu membayar biaya pada akun Google Cloud Anda untuk resource yang digunakan dalam tutorial ini, hapus project yang berisi resource tersebut, atau simpan project dan hapus setiap resource.
Menghapus project
- 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.
Menghapus resource satu per satu
Langkah berikutnya
- Pelajari jenis notifikasi cluster.
- Lihat dokumentasi Pub/Sub.