Ringkasan alur kerja

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 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 mengharapkannya 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:

Orkestrasi layanan menggunakan Workflows

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:
  • Mengirim file yang baru diupload ke Cloud Vision AI, lalu menulis tag ke Firestore
  • Memanggil fungsi Cloud Run dan mengirim hasilnya ke layanan Cloud Run
Tugas batch Beroperasi pada beberapa item—Melakukan operasi pada kumpulan item atau data batch. Sering dijadwalkan. Contoh:
  • Mengirim email harian kepada pelanggan
  • Menyiapkan dan menjalankan tugas BigQuery atau machine learning
  • Membuat laporan
Proses bisnis Mengotomatiskan alur kerja lini bisnis—Mengenkode langkah-langkah dalam proses bisnis, termasuk kondisi, tindakan, dan peristiwa human-in-the-loop. Contoh:
  • Melacak pesanan dari permintaan hingga pemenuhan
  • Mengotomatiskan permintaan resource dengan persetujuan
Otomatisasi proses IT Eksekusi terkelola operasi layanan—Buat skrip urutan operasi layanan Google Cloud dengan mudah. Misalnya:
  • Menyediakan infrastruktur atau project tenant baru
  • Menurunkan resource sesuai jadwal atau melalui pemicu peristiwa

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 minimal satu langkah. Secara default, Workflows 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 oleh 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 blok main). Blok main menerima satu argumen yang merupakan jenis data JSON yang valid. Kolom params 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 Cloudseperti 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 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 API Google Cloud lainnya dalam alur kerja, dan untuk mengintegrasikan alur kerja Anda dengan produk Google Cloud tersebut. API ini menyederhanakan layanan panggilan karena menangani pemformatan permintaan untuk Anda, dan menyediakan metode dan argumen sehingga Anda tidak perlu mengetahui detail APIGoogle Cloud . 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 Anda 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 yang ditentukan 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 API Google Cloud 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