Alur kerja adalah platform orkestrasi terkelola sepenuhnya yang menjalankan layanan dalam urutan yang Anda tentukan: alur kerja. Alur kerja ini dapat menggabungkan berbagai layanan termasuk layanan kustom yang dihosting di Cloud Run atau fungsi Cloud Run, layanan Google Cloud seperti Cloud Vision AI dan BigQuery, serta API berbasis HTTP apa pun.
Dengan menggabungkan Alur Kerja ke dalam solusi, Anda dapat membuat dependensi layanan menjadi eksplisit dan dapat diamati secara menyeluruh. Alur kerja yang menentukan proses aplikasi, operasional, atau bisnis memberikan sumber tepercaya atau narasi kanonis untuk proses tersebut.
Alur kerja bersifat serverless, diskalakan sesuai kebutuhan, dan tidak ada biaya yang dikenakan saat tidak ada aktivitas. Karena tidak berisi dependensi kode atau library, alur kerja tidak memerlukan patch keamanan. Setelah men-deploy alur kerja, Anda dapat mengharapkan alur kerja tersebut dieksekusi dengan andal tanpa pemeliharaan. Alur kerja dapat menyimpan status, mencoba ulang, melakukan polling, atau menunggu hingga satu tahun.
Alur kerja mematuhi sertifikasi dan standar ini.
Diagram berikut menunjukkan contoh penggunaan Alur Kerja untuk mengelola layanan:
Kasus penggunaan utama
Alur kerja mendukung banyak kasus penggunaan. Berikut beberapa contohnya:
Orkestrasi layanan | Membuat solusi dengan menggabungkan layanan—Melakukan urutan operasi di beberapa sistem, menunggu semua operasi selesai.
Dapat berbasis peristiwa. Contoh:
|
Tugas batch | Beroperasi pada beberapa item—Melakukan operasi pada kumpulan item atau data batch. Sering dijadwalkan. Contoh:
|
Proses bisnis | Mengotomatiskan alur kerja lini bisnis—Mengenkode langkah-langkah dalam
proses bisnis, termasuk kondisi, tindakan, dan peristiwa human-in-the-loop. Contoh:
|
Otomatisasi proses IT | Ekseskusi terkelola operasi layanan—Buat skrip urutan operasi layanan Google Cloud dengan mudah. Contoh:
|
Konsep inti
Alur kerja terdiri dari serangkaian langkah yang dijelaskan menggunakan sintaksis Workflows, dan dapat ditulis dalam YAML atau JSON. Ini adalah definisi alur kerja. Untuk penjelasan mendetail tentang sintaksis Alur Kerja, lihat Referensi sintaksis.
Setelah dibuat, alur kerja akan di-deploy, sehingga alur kerja siap untuk dieksekusi. Pelajari cara membuat dan memperbarui alur kerja di Konsol Google Cloud atau menggunakan Google Cloud CLI. Anda juga dapat membuat alur kerja dengan menggunakan IDE atau editor kode sumber pilihan dan menyiapkan pelengkapan otomatis dan validasi sintaksis.
Eksekusi adalah satu eksekusi logika yang terkandung dalam definisi
alur kerja. Alur kerja yang belum dieksekusi tidak akan dikenai biaya. Semua
eksekusi alur kerja bersifat independen, dan penskalaan produk yang cepat memungkinkan
banyak eksekusi serentak. Anda dapat menjalankan alur kerja menggunakan
library klien, di konsol Google Cloud, menggunakan Google Cloud CLI,
atau dengan mengirim permintaan POST
HTTP ke URL pemanggilan alur kerja menggunakan
Workflows REST API. Untuk mengetahui detailnya, lihat
Menjalankan alur kerja.
Regionalitas
Alur kerja adalah layanan regional dan alur kerja adalah resource regional yang tunduk pada batasan lokasi resource. Anda dapat menggunakan kebijakan lokasi resource untuk mengontrol residensi data.
Perhatikan bahwa saat di-deploy ke region tertentu, alur kerja hanya dijalankan di region tersebut; tetapi, jika alur kerja membuat permintaan HTTP atau menggunakan konektor, panggilan HTTP mungkin tidak berasal dari region yang sama.
Kemampuan utama
Berikut adalah beberapa kemampuan utama Alur Kerja.
Kontrol eksekusi
- Langkah
- Untuk membuat alur kerja, Anda menentukan langkah-langkah dan urutan eksekusi yang diperlukan menggunakan sintaksis Alur Kerja. Setiap alur kerja harus memiliki setidaknya satu langkah. Secara default, Alur Kerja memperlakukan langkah-langkah seolah-olah berada dalam daftar yang diurutkan dan menjalankannya satu per satu hingga semua langkah telah berjalan. Untuk mengetahui detailnya, lihat Langkah-langkah.
- Kondisi
- Anda dapat menggunakan blok
switch
sebagai mekanisme pemilihan yang memungkinkan nilai ekspresi mengontrol alur eksekusi alur kerja. Untuk mengetahui detailnya, lihat Kondisi. - Iterasi
- Anda dapat menggunakan loop
for
untuk melakukan iterasi pada urutan angka atau melalui kumpulan data, seperti daftar atau peta. Untuk mengetahui detailnya, lihat Iterasi. - Langkah paralel
- Anda dapat menggunakan langkah
parallel
untuk menentukan bagian dari alur kerja (cabang atau loop) yang dapat dijalankan secara serentak. Untuk mengetahui detailnya, lihat Langkah paralel. - Subalur kerja
- Subalur kerja berfungsi mirip dengan rutinitas atau fungsi dalam bahasa pemrograman, yang memungkinkan Anda mengenkapsulasi langkah atau serangkaian langkah yang akan berulang beberapa kali dalam alur kerja Anda. Untuk mengetahui detailnya, lihat Subalur kerja.
Memicu eksekusi
- Manual
- Anda dapat mengelola alur kerja dari konsol Google Cloud atau dari command line menggunakan Google Cloud CLI. Dukungan visualisasi saat mengedit sintaksis Alur Kerja juga tersedia melalui konsol Google Cloud.
- Terprogram
- Library Klien Cloud untuk Workflows API, atau REST API, dapat digunakan untuk mengelola alur kerja. Untuk mengetahui detailnya, lihat API dan referensi Alur Kerja.
- Dijadwalkan
- Anda dapat menggunakan Cloud Scheduler untuk menjalankan alur kerja pada jadwal tertentu, seperti setiap hari Senin pukul 09.00 atau setiap 15 menit. Untuk mengetahui detailnya, lihat Menjadwalkan alur kerja menggunakan Cloud Scheduler.
- Argumen runtime
- Data yang diteruskan saat runtime dapat diakses dengan menambahkan kolom
params
ke alur kerja utama Anda (ditempatkan dalam blokmain
). Blokmain
menerima satu argumen yang merupakan jenis data JSON yang valid. Kolomparams
memberi nama variabel yang digunakan alur kerja untuk menyimpan data yang Anda teruskan. Untuk mengetahui detailnya, lihat Argumen runtime.
Menghubungkan layanan
- HTTP API
- Anda dapat menentukan langkah alur kerja yang melakukan panggilan HTTP dan menetapkan respons dari panggilan ke variabel. Misalnya, Anda dapat memanggil layanan Google Cloud seperti fungsi Cloud Run atau Cloud Run melalui permintaan HTTP. Permintaan HTTP dan HTTPS didukung. Untuk mengetahui detailnya, lihat artikel Membuat permintaan HTTP dan Memanggil fungsi Cloud Run atau Cloud Run.
- Anda dapat memanggil endpoint lokal pribadi, Compute Engine, Google Kubernetes Engine (GKE), atau endpoint Google Cloud lainnya dengan mengaktifkan Identity-Aware Proxy (IAP). Dengan IAP, Anda dapat membuat lapisan otorisasi pusat untuk aplikasi yang diakses oleh HTTPS. Dengan begitu, Anda dapat menggunakan model kontrol akses tingkat aplikasi, bukan mengandalkan firewall tingkat jaringan. Untuk mengetahui informasi selengkapnya, lihat Memanggil endpoint lokal pribadi, Compute Engine, GKE, atau endpoint lainnya.
- Atau, Anda dapat menargetkan endpoint pribadi untuk panggilan HTTP dari eksekusi alur kerja menggunakan registry layanan Service Directory dengan Alur Kerja. Dengan membuat endpoint pribadi dalam jaringan Virtual Private Cloud (VPC), endpoint tersebut dapat mematuhi Kontrol Layanan VPC. Untuk mengetahui informasi selengkapnya, lihat Memanggil endpoint pribadi yang sesuai dengan Kontrol Layanan VPC.
- Konektor
- Alur kerja memublikasikan konektor yang dapat digunakan untuk terhubung ke Google Cloud API lainnya dalam alur kerja, dan untuk mengintegrasikan alur kerja Anda dengan produk Google Cloud tersebut. Library ini menyederhanakan layanan panggilan karena menangani pemformatan permintaan untuk Anda, dan menyediakan metode serta argumen sehingga Anda tidak perlu mengetahui detail Google Cloud API. Untuk mengetahui detailnya, lihat Memahami konektor.
- Variabel lingkungan dan library standar
- Library standar Alur Kerja, variabel lingkungan bawaan, dan variabel lingkungan buatan pengguna memungkinkan Anda membuat argumen untuk layanan dan memproses respons secara efisien.
- Library standar mencakup modul dan fungsi yang sering digunakan, seperti untuk jenis data dan konversi format. Anda tidak perlu mengimpor atau memuat library dalam alur kerja—fungsi library akan langsung berfungsi. Untuk mengetahui detailnya, lihat Ringkasan library standar.
- Anda dapat mengakses informasi lingkungan alur kerja (seperti lokasi atau ID project) menggunakan variabel lingkungan bawaan. Variabel lingkungan bawaan tidak memerlukan deklarasi dan tersedia di setiap eksekusi alur kerja. Untuk mengetahui detailnya, lihat Variabel lingkungan bawaan.
- Saat men-deploy alur kerja, Anda dapat menetapkan pasangan string kunci dan nilai arbitrer sebagai variabel lingkungan yang ditentukan pengguna yang dapat diakses oleh alur kerja Anda saat runtime. Misalnya, Anda dapat membuat alur kerja yang dikonfigurasi secara dinamis bergantung pada lingkungan tempat alur kerja tersebut di-deploy. Untuk mengetahui detailnya, lihat Menggunakan variabel lingkungan.
Penanganan error
Anda dapat membuat alur kerja menjadi tangguh dan menyesuaikan perilakunya saat terjadi kegagalan dengan menggunakan penanganan pengecualian Alur Kerja, termasuk percobaan ulang panggilan HTTP otomatis dengan backoff eksponensial, pengendali error kustom, dan fitur lanjutan lainnya. Untuk mengetahui detailnya, lihat Error alur kerja.
Menunggu
Callback memungkinkan eksekusi alur kerja menunggu layanan lain membuat permintaan ke endpoint callback; permintaan tersebut akan melanjutkan eksekusi alur kerja. Dengan callback, Anda dapat memberi sinyal ke alur kerja bahwa peristiwa tertentu telah terjadi, dan menunggu peristiwa tersebut tanpa polling. Untuk mengetahui detailnya, lihat Menunggu menggunakan callback.
Anda dapat menjeda eksekusi alur kerja dengan menambahkan langkah tidur ke definisi alur kerja. Kemudian, Anda dapat menggunakan sys.sleep
untuk melakukan polling data selama
interval tertentu. Untuk mengetahui detailnya, lihat Menunggu menggunakan polling.
Autentikasi dan kontrol akses
Karena setiap eksekusi alur kerja memerlukan panggilan yang diautentikasi, Anda dapat mengurangi risiko panggilan yang tidak disengaja atau berbahaya dengan menggunakan Alur Kerja. Anda juga dapat menyederhanakan interaksi dengan Google Cloud API lainnya menggunakan akun layanan berbasis IAM, dan Anda dapat menyimpan kunci dan sandi dengan aman untuk mengautentikasi ke API eksternal menggunakan konektor Secret Manager. Untuk mengetahui detailnya, pelajari autentikasi dan kontrol akses lebih lanjut.
Kemampuan observasi
Alur kerja secara otomatis membuat log eksekusi untuk eksekusi alur kerja di Cloud Logging. Anda juga dapat mengontrol kapan log dikirim ke Logging selama eksekusi alur kerja melalui logging panggilan atau log kustom. Untuk mengetahui detailnya, lihat Mengirim log ke Cloud Logging.
Informasi logging audit tersedia melalui Cloud Audit Logs. Untuk mengetahui detailnya, lihat informasi logging audit untuk alur kerja dan eksekusi alur kerja.
Anda dapat mengambil histori eksekusi alur kerja yang ditentukan sebagai daftar entri langkah. Setiap entri mewakili langkah atau blok petunjuk dalam eksekusi alur kerja. Entri langkah dapat membantu Anda menentukan sumber error atau mengoptimalkan performa alur kerja.
Contoh kode
Anda dapat menemukan banyak contoh kode Workflows yang berguna di halaman contoh.
Langkah selanjutnya
Mulai gunakan Alur Kerja dari konsol Google Cloud atau menggunakan gcloud CLI.
Pelajari lebih lanjut cara membuat dan memperbarui alur kerja.
Pelajari cara mengontrol urutan langkah-langkah alur kerja yang dijalankan.