Mengelola cron job

Target Pub/Sub

Jika Anda memilih jenis target Pub/Sub:

  1. Tentukan nama topik tempat tugas akan dipublikasikan. Ini adalah topik Pub/Sub yang telah Anda siapkan di project.

  2. Tentukan pesan yang akan dikirim ke topik. Ini dikirim sebagai parameter data dalam pesan Pub/Sub. Untuk mengetahui contoh yang melakukan hal ini, lihat Panduan Memulai.

  3. Tambahkan atribut pesan yang Anda perlukan.

  4. Siapkan konfigurasi tambahan menggunakan bagian Configure optional settings.

Cloud Scheduler akan memublikasikan pesan ke topik ini sebagai akun layanan Google API.

Target HTTP App Engine

Jika memilih jenis target App Engine HTTP, Anda harus menggunakan aplikasi App Engine dan region yang terkait dengan project saat ini. Jika Anda ingin menggunakan beberapa aplikasi App Engine lain di luar project saat ini, pilih HTTP sebagai target, bukan App Engine HTTP. Aturan firewall target harus mengizinkan permintaan dari rentang IP 0.1.0.2/32.

Tetapkan formulir sebagai berikut:

  1. Dalam daftar Jenis target, pilih HTTP App Engine.

  2. Tentukan nama layanan App Engine yang menjalankan pengendali untuk tugas Cloud Scheduler. Jika dihilangkan, layanan default akan diasumsikan. Jika ingin menetapkannya, Anda dapat menemukan nama layanan di konsol Google Cloud.

  3. Secara opsional, tentukan versi. Jika tidak ditetapkan, versi yang saat ini ditayangkan akan digunakan. Anda dapat menemukan versi yang tersedia di konsol Google Cloud.

  4. Secara opsional, tentukan instance. Jika tidak ditetapkan, instance apa pun yang tersedia dapat digunakan. Anda dapat menemukan versi yang tersedia di konsol Google Cloud.

  5. Tentukan URL relatif endpoint App Engine yang akan dihubungi tugas. Jika Anda menggunakan nilai default /, tugas akan menggunakan PROJECT-ID.appspot.com dengan PROJECT-ID adalah project ID Anda saat ini.

  6. Tetapkan metode HTTP yang ingin Anda gunakan saat tugas dieksekusi. Defaultnya adalah POST.

  7. Tambahkan header yang Anda perlukan ke permintaan.

  8. Secara opsional, tentukan data isi yang akan dikirim ke target. Data ini dikirim dalam isi permintaan sebagai byte saat metode HTTP POST atau PUT dipilih.

Endpoint App Engine yang ditargetkan harus berada dalam project yang sama dan dapat diamankan dengan login: admin pada elemen handlers dalam file app.yaml.

Target HTTP

Jika Anda memilih jenis target HTTP:

  1. Tentukan URL endpoint yang sepenuhnya memenuhi syarat yang akan dihubungi tugas.

  2. Tentukan metode HTTP. Nilai defaultnya adalah POST.

  3. (Opsional) Tentukan data yang akan dikirim ke target. Data ini dikirim dalam isi permintaan sebagai byte jika metode HTTP POST atau PUT dipilih.

  4. Tambahkan header yang Anda perlukan.

  5. Untuk membuat tugas target HTTP yang memerlukan autentikasi, lihat Menggunakan autentikasi dengan target HTTP.

Endpoint HTTP yang ditargetkan harus dapat diakses secara publik.

Anda dapat menggunakan Cloud Scheduler untuk menyiapkan unit tugas terjadwal, yang dikenal sebagai cron job, yang dikirim ke target pada beberapa jadwal berulang, yang juga disebut interval atau frekuensi tugas.

Hanya satu instance tugas yang dapat dijalankan pada satu waktu. Dalam situasi yang jarang terjadi, beberapa instance dari pekerjaan yang sama dapat diminta. Akibatnya, pengendali permintaan Anda harus bersifat idempotent, dan kode Anda harus memastikan bahwa tidak ada efek samping yang berbahaya jika hal ini terjadi.

Cloud Scheduler ditujukan untuk tugas berulang. Jika Anda hanya perlu menjalankan tugas satu kali, pertimbangkan untuk menggunakan Cloud Tasks, yang dapat menjadwalkan tugas hingga 30 hari sebelumnya.

Sebelum memulai

Pastikan Anda telah menyiapkan lingkungan untuk Cloud Scheduler.

Memilih jenis target

Cloud Scheduler dapat memanggil jenis target berikut:

Memanggil layanan target yang dibatasi untuk ingress internal

Cloud Scheduler dapat memanggil layanan berikut secara internal:

  • Fungsi Cloud Run
  • Cloud Run (di URL run.app, bukan di domain kustom)

Untuk memanggil target ini secara internal, target harus berada dalam project Google Cloud atau perimeter Kontrol Layanan VPC yang sama dengan tugas Cloud Scheduler Anda.

Untuk mempelajari lebih lanjut cara mengamankan target dengan membatasi traffic masuk, lihat Membatasi traffic masuk (untuk Cloud Run) dan Mengonfigurasi setelan jaringan (untuk fungsi Cloud Run).

Buat tugas

Anda dapat membuat tugas menggunakan konsol Google Cloud atau Google Cloud CLI.

Konsol

  1. Di konsol Google Cloud, buka halaman Cloud Scheduler.

    Buka Cloud Scheduler

  2. Klik Buat tugas.

  3. Di kolom Name, berikan nama untuk tugas yang unik untuk project.

    Setelah menghapus tugas terkaitnya, Anda dapat menggunakan kembali nama tugas dalam project.

  4. Di daftar Region, pilih region.

    Jika menggunakan target HTTP App Engine, Anda harus memilih region yang sama dengan aplikasi App Engine. Untuk informasi selengkapnya, lihat Region yang didukung berdasarkan target.

  5. Secara opsional, berikan deskripsi singkat tentang tugas, seperti pengingat tentang tugas yang dilakukan.

    Deskripsi ini muncul di konsol di samping nama tugas.

  6. Tentukan frekuensi saat tugas akan dijalankan, menggunakan string konfigurasi.

    Misalnya, string 0 1 * * 0 menjalankan tugas sekali seminggu pada pukul 01.00 setiap Minggu pagi. String yang Anda berikan di sini dapat berupa string apa pun yang kompatibel dengan unix-cron. Untuk informasi selengkapnya, lihat Mengonfigurasi jadwal tugas cron.

  7. Dalam daftar Zona Waktu, pilih zona waktu yang akan digunakan untuk jadwal tugas.

  8. Klik Lanjutkan.

  9. Tentukan Jenis target:

    • HTTP

    • Pub/Sub: Anda harus menentukan nama topik Pub/Sub yang telah disiapkan di project dan tempat tugas akan dipublikasikan.

    • HTTP App Engine: Anda harus menggunakan aplikasi App Engine dan region yang terkait dengan project saat ini.

  10. Klik Lanjutkan.

  11. Secara opsional, untuk mengonfigurasi perilaku percobaan ulang, klik Konfigurasikan setelan opsional. Untuk menentukan durasi, gunakan urutan bilangan bulat non-negatif desimal dengan akhiran unit berikut:

    • h - jam
    • m - menit
    • s - detik
    • ms - milidetik
    • us - mikrodetik
    • ns - nanodetik

    Nilai negatif dan pecahan tidak diizinkan. Kolom Max retry duration hanya mendukung nilai h ,m, dan s. Min backoff duration dan Max backoff duration mendukung kumpulan lengkap.

  12. Secara opsional, untuk target HTTP dan HTTP App Engine, konfigurasikan batas waktu untuk percobaan tugas. Jika pengendali permintaan tidak merespons sebelum batas waktu ini, permintaan akan dibatalkan dan upaya akan ditandai sebagai gagal. Cloud Scheduler akan mencoba kembali tugas sesuai dengan konfigurasi percobaan ulang.

  13. Untuk membuat dan menyimpan tugas, klik Buat.

    Tugas sekarang akan berjalan pada frekuensi yang ditentukan.

gcloud

Saat membuat tugas menggunakan gcloud CLI, Anda menggunakan perintah yang berbeda untuk setiap jenis target:

HTTP

Anda dapat mengirim permintaan ke endpoint HTTP atau HTTPS. Endpoint HTTP yang ditargetkan harus dapat diakses secara publik.

gcloud scheduler jobs create http JOB \
    --location=LOCATION \
    --schedule=SCHEDULE \
    --uri=URI

Ganti kode berikut:

  • JOB: nama tugas yang harus unik dalam project. Perhatikan bahwa Anda tidak dapat menggunakan kembali nama tugas dalam sebuah project meskipun menghapus tugas terkaitnya.

  • LOCATION: lokasi tempat tugas Anda akan dijalankan.

  • SCHEDULE: frekuensi, atau interval tugas, saat tugas akan dijalankan, misalnya, every 3 hours. String yang Anda berikan di sini dapat berupa string apa pun yang kompatibel dengan unix-cron. Meskipun kami tidak lagi merekomendasikan penggunaannya, sintaksis cron App Engine lama masih didukung untuk tugas yang ada.

    Untuk informasi selengkapnya, lihat Mengonfigurasi jadwal tugas cron.

  • URI: URI endpoint yang sepenuhnya memenuhi syarat yang akan dihubungi tugas.

Parameter lainnya dijelaskan dalam referensi command line gcloud:

  • Secara opsional, tentukan metode HTTP. Nilai defaultnya adalah POST.

  • (Opsional) Tentukan data yang akan dikirim ke target. Data ini dikirim dalam isi permintaan sebagai byte jika metode HTTP POST atau PUT dipilih.

  • Atau, tetapkan nilai percobaan ulang, yang menentukan cara tugas App Engine akan dicoba ulang jika terjadi kegagalan. Dalam sebagian besar kasus, setelan default akan sudah cukup.

  • Untuk membuat tugas Target HTTP yang memerlukan autentikasi, lihat Menggunakan Autentikasi dengan Target HTTP.

Contoh

gcloud scheduler jobs create http my-http-job \
    --schedule "0 1 * * 0" \
    --uri "http://myproject/my-url.com" \
    --http-method GET

Pub/Sub

Anda harus menggunakan topik Pub/Sub yang telah disiapkan di project Anda. Cloud Scheduler akan memublikasikan pesan ke topik ini sebagai akun layanan Google API.

gcloud scheduler jobs create pubsub JOB \
    --location=LOCATION \
    --schedule=SCHEDULE \
    --topic=TOPIC

Ganti kode berikut:

  • JOB: nama tugas yang harus unik dalam project. Perhatikan bahwa Anda tidak dapat menggunakan kembali nama tugas dalam sebuah project meskipun menghapus tugas terkaitnya.

  • LOCATION: lokasi tempat tugas Anda akan dijalankan.

  • SCHEDULE: frekuensi, atau interval tugas, saat tugas akan dijalankan, misalnya, every 3 hours. String yang Anda berikan di sini dapat berupa string apa pun yang kompatibel dengan unix-cron. Meskipun kami tidak lagi merekomendasikan penggunaannya, sintaksis cron App Engine lama masih didukung untuk tugas yang ada.

    Untuk informasi selengkapnya, lihat Mengonfigurasi jadwal tugas cron.

  • TOPIC: nama topik tempat tugas akan dipublikasikan. Gunakan flag --message-body atau --message-body-from-file, untuk menentukan pesan yang akan dikirim ke topik. Ini dikirim sebagai parameter data dalam pesan Pub/Sub. Untuk mengetahui contoh yang melakukan hal ini, lihat panduan memulai.

Parameter lainnya dijelaskan dalam referensi command line gcloud.

Contoh

gcloud scheduler jobs create pubsub myjob \
    --schedule "0 1 * * 0" \
    --topic cron-topic \
    --message-body "Hello"

HTTP App Engine

Target App Engine HTTP hanya tersedia untuk aplikasi App Engine yang dikaitkan dengan project saat ini. Jika Anda ingin menggunakan beberapa aplikasi App Engine lain di luar project saat ini, pilih HTTP sebagai target, bukan App Engine HTTP. Aturan firewall target harus mengizinkan permintaan dari rentang IP 0.1.0.2/32.

Endpoint App Engine dapat diamankan dengan login: admin pada elemen handlers dalam file app.yaml.

gcloud scheduler jobs create app-engine \
    --JOB=JOB \
    --location=LOCATION \
    --schedule=SCHEDULE

Ganti kode berikut:

  • JOB: nama tugas yang harus unik dalam project. Perhatikan bahwa Anda tidak dapat menggunakan kembali nama tugas dalam sebuah project meskipun menghapus tugas terkaitnya.

  • LOCATION: lokasi tempat tugas Anda akan dijalankan. Lokasi ini harus sama dengan lokasi aplikasi App Engine Anda.

  • SCHEDULE: frekuensi, atau interval tugas, saat tugas akan dijalankan, misalnya, every 3 hours. String yang Anda berikan di sini dapat berupa string apa pun yang kompatibel dengan unix-cron. Meskipun kami tidak lagi merekomendasikan penggunaannya, sintaksis cron App Engine lama masih didukung untuk tugas yang ada.

    Untuk informasi selengkapnya, lihat Mengonfigurasi jadwal tugas cron.

Parameter lainnya dijelaskan dalam referensi command line gcloud:

  • Tentukan URL relatif endpoint App Engine yang akan dihubungi oleh tugas. Jika Anda menggunakan nilai default /, tugas akan menggunakan PROJECT-ID.appspot.com dengan PROJECT-ID adalah project ID Anda saat ini.

  • Tentukan nama layanan App Engine yang menjalankan pengendali untuk tugas Cloud Scheduler. Jika dihilangkan, layanan default akan diasumsikan. Jika ingin menetapkannya, Anda dapat menemukan nama layanan di konsol Google Cloud.

  • Secara opsional, tetapkan metode HTTP yang ingin Anda gunakan saat tugas dieksekusi. Nilai defaultnya adalah POST.

  • Secara opsional, tentukan versi. Jika tidak disetel, versi yang saat ini ditayangkan akan digunakan. Anda dapat menemukan versi yang tersedia di konsol Google Cloud.

  • Secara opsional, tentukan instance. Jika tidak ditetapkan, instance apa pun yang tersedia dapat digunakan. Anda dapat menemukan versi yang tersedia di konsol Google Cloud.

  • (Opsional) Tentukan data yang akan dikirim ke target. Data ini dikirim dalam isi permintaan sebagai byte jika metode HTTP POST atau PUT dipilih.

  • Atau, tetapkan nilai percobaan ulang, yang menentukan cara tugas App Engine akan dicoba ulang jika terjadi kegagalan. Dalam sebagian besar kasus, setelan default sudah memadai.

Contoh

gcloud scheduler jobs create app-engine my-appengine-job \
    --schedule "0 1 * * 0" \
    --relative-url "/cron-handler"

Mengedit tugas

Anda dapat mengedit konfigurasi tugas.

Konsol

  1. Di konsol Google Cloud, buka halaman Cloud Scheduler.

    Buka Cloud Scheduler

  2. Pilih tugas yang akan diedit.

  3. Klik Edit.

  4. Ikuti langkah-langkah untuk menentukan jadwal, mengonfigurasi eksekusi, dan mengonfigurasi setelan opsional saat membuat tugas.

gcloud

Saat mengedit tugas menggunakan gcloud CLI, Anda menggunakan perintah yang berbeda untuk setiap jenis target:

HTTP

Anda dapat mengirim permintaan ke endpoint HTTP atau HTTPS. Endpoint HTTP yang ditargetkan harus dapat diakses secara publik.

gcloud scheduler jobs update http JOB \
    --location=LOCATION \
    --schedule=SCHEDULE \
    --uri=URI

Ganti kode berikut:

  • JOB: nama tugas yang harus unik dalam project. Perhatikan bahwa Anda tidak dapat menggunakan kembali nama tugas dalam sebuah project meskipun menghapus tugas terkaitnya.

  • LOCATION: lokasi tempat tugas Anda berjalan. Jika Anda tidak menentukan lokasi, gcloud CLI akan menggunakan lokasi default Anda. Jika tugas yang ingin diedit berada di lokasi yang berbeda, Anda harus menentukan lokasi selain NAME agar tugas Anda dapat diidentifikasi. Anda tidak dapat memperbarui lokasi lowongan.

  • SCHEDULE: frekuensi, atau interval tugas, saat tugas akan dijalankan, misalnya, every 3 hours. String yang Anda berikan di sini dapat berupa string apa pun yang kompatibel dengan unix-cron. Meskipun kami tidak lagi merekomendasikan penggunaannya, sintaksis cron App Engine lama masih didukung untuk tugas yang ada.

    Untuk informasi selengkapnya, lihat Mengonfigurasi jadwal tugas cron.

  • URI: URI endpoint yang sepenuhnya memenuhi syarat yang akan dihubungi tugas.

Parameter lainnya dijelaskan dalam referensi command line gcloud.

Contoh

gcloud scheduler jobs update http my-http-job \
    --schedule "0 1 * * 0" \
    --uri "http://myproject/my-url.com" \
    --http-method GET

Pub/Sub

Anda harus menggunakan topik Pub/Sub yang telah disiapkan di project Anda. Cloud Scheduler akan memublikasikan pesan ke topik ini sebagai akun layanan Google API.

gcloud scheduler jobs update pubsub JOB \
    --location=LOCATION \
    --schedule=SCHEDULE \
    --topic=TOPIC

Ganti kode berikut:

  • JOB: nama tugas yang harus unik dalam project. Perhatikan bahwa Anda tidak dapat menggunakan kembali nama tugas dalam sebuah project meskipun menghapus tugas terkaitnya.

  • LOCATION: lokasi tempat tugas Anda berjalan. Jika Anda tidak menentukan lokasi, gcloud CLI akan menggunakan lokasi default Anda. Jika tugas yang ingin diedit berada di lokasi yang berbeda, Anda harus menentukan lokasi selain NAME agar tugas Anda dapat diidentifikasi. Anda tidak dapat memperbarui lokasi lowongan.

  • SCHEDULE: frekuensi, atau interval tugas, saat tugas akan dijalankan, misalnya, every 3 hours. String yang Anda berikan di sini dapat berupa string apa pun yang kompatibel dengan unix-cron. Meskipun kami tidak lagi merekomendasikan penggunaannya, sintaksis cron App Engine lama masih didukung untuk tugas yang ada.

    Untuk informasi selengkapnya, lihat Mengonfigurasi jadwal tugas cron.

  • TOPIC: nama topik tempat tugas akan dipublikasikan. Gunakan flag --message-body atau --message-body-from-file untuk menentukan pesan yang akan dikirim ke topik. Ini dikirim sebagai parameter data dalam pesan Pub/Sub. Untuk mengetahui contoh yang melakukan hal ini, lihat panduan memulai.

Parameter lainnya dijelaskan dalam referensi command line gcloud.

Contoh

gcloud scheduler jobs update pubsub myjob \
    --schedule "0 1 * * 0" \
    --topic cron-topic --message-body "Hello"

HTTP App Engine

Target App Engine HTTP hanya tersedia untuk aplikasi App Engine yang dikaitkan dengan project saat ini. Jika Anda ingin menggunakan beberapa aplikasi App Engine lain di luar project saat ini, pilih HTTP sebagai target, bukan App Engine HTTP.

Endpoint App Engine dapat diamankan dengan login: admin pada elemen handlers dalam file app.yaml.

gcloud scheduler jobs update app-engine JOB \
    --location=LOCATION \
    --schedule=SCHEDULE

Ganti kode berikut:

  • JOB: nama tugas yang harus unik dalam project. Perhatikan bahwa Anda tidak dapat menggunakan kembali nama tugas dalam sebuah project meskipun menghapus tugas terkaitnya.

  • LOCATION: lokasi tempat tugas Anda berjalan (sama dengan lokasi aplikasi App Engine target Anda). Jika Anda tidak menentukan lokasi, gcloud CLI akan menggunakan lokasi default Anda. Jika tugas yang ingin diedit berada di lokasi yang berbeda, Anda harus menentukan lokasi selain NAME agar tugas Anda dapat diidentifikasi. Anda tidak dapat memperbarui lokasi lowongan.

  • SCHEDULE: frekuensi, atau interval tugas, saat tugas akan dijalankan, misalnya, every 3 hours. String yang Anda berikan di sini dapat berupa string apa pun yang kompatibel dengan unix-cron. Meskipun kami tidak lagi merekomendasikan penggunaannya, sintaksis cron App Engine lama masih didukung untuk tugas yang ada.

    Untuk informasi selengkapnya, lihat Mengonfigurasi jadwal tugas cron.

Parameter lainnya dijelaskan dalam referensi command line gcloud.

Contoh

gcloud scheduler jobs update app-engine my-appengine-job \
    --schedule "0 1 * * 0" \
    --relative-url "/cron-handler"

Menjeda tugas

Anda dapat menjeda eksekusi tugas.

Konsol

  1. Di konsol Google Cloud, buka Cloud Scheduler.

    Buka Cloud Scheduler

  2. Pilih tugas yang ingin dijeda.

  3. Klik Pause.

gcloud

  1. Buka jendela terminal di mesin tempat Anda menginstal gcloud CLI.

  2. Jalankan perintah:

     gcloud scheduler jobs pause MY_JOB
    

    Ganti MY_JOB dengan nama tugas yang akan dijeda.

Saat tugas dijeda, Anda juga dapat mengeditnya. Setelah diedit, tugas tersebut tetap dijeda hingga Anda melanjutkannya.

Melanjutkan tugas

Anda dapat melanjutkan eksekusi tugas yang dijeda.

Konsol

  1. Di konsol Google Cloud, buka Cloud Scheduler.

    Buka Cloud Scheduler

  2. Pilih tugas yang akan dilanjutkan.

    Tugas harus sudah dijeda.

  3. Klik Lanjutkan.

gcloud

  1. Buka jendela terminal di mesin tempat Anda menginstal gcloud CLI.

  2. Jalankan perintah:

     gcloud scheduler jobs resume MY_JOB
    

    Ganti MY_JOB dengan nama tugas yang akan dilanjutkan.

Menghapus tugas

Anda dapat menghapus tugas.

Konsol

  1. Di konsol Google Cloud, buka Cloud Scheduler.

    Buka Cloud Scheduler

  2. Pilih tugas yang akan dihapus.

  3. Klik Hapus.

gcloud

  1. Buka jendela terminal di mesin tempat Anda menginstal gcloud CLI.

  2. Jalankan perintah:

     gcloud scheduler jobs delete MY_JOB
    

    Ganti MY_JOB dengan nama tugas yang akan dihapus.