Skip to content Skip to sidebar Skip to footer

Cara Konfigurasi Cron Job di VPS Digital Ocean (Ubuntu 20.04)

Ada saat ketika kita ingin melakukan suatu task/tugas yang secara otomatis dapat menjalankan secara terus-menerus atau terjadwal di server VPS kita. Entah itu mengirim email ke pengguna, backup database harian/mingguan/bulanan, atau hanya menjalankan script-script tertentu.

Semua bisa dengan Cron Job ini. Cron Job merupakan task/tugas yang dieksekusi secara terjadwal di sistem operasi Linux, Unix Systems, yang mana dapat mengeksekusi perintah shell pada waktu tertentu.

Sebenarnya sudah ada artikel yang membahas tentang ini, hanya saja artikelnya berbahasa inggris. Jadi, saya ingin menulisnya dalam bahasa Indonesia. 😀

Persyaratan untuk tutorial ini

Sebelum memulai langkah-langkahnya, pastikan dulu:

1. VPS Digital Ocean

Karena tutorial kali ini hanya fokus untuk VPS milik Digital Ocean, jadi saya tidak tahu untuk VPS lainnya jika ada masalah atau tidak.

2. OS Ubuntu versi 18.04 ke atas

Jika versinya di bawah 18.04, dikhawatirkan tidak cocok atau support terhadap perintah yang akan dijalankan nanti. Karena saya juga mencari tutorialnya dari versi 18.04.

Oh, iya disarankan juga untuk membuat user baru yang tidak langsung masuk sebagai root ketika login ke Droplet. Untuk caranya bisa lihat di panduan ini, karena saya tidak membahas secara mendalam pada tutorial kali ini.

Yap, hanya dua hal itu saja. Mari kita coba...

Sebelum menggunakan cron, pastikan juga cron telah diinstall dengan cara:

sudo apt update

Kemudian:

sudo apt install cron

Jika sudah, kita aktifkan agar cron dapat berjalan di background:

sudo systemctl enable cron

Outputnya akan menjadi seperti ini, jika berhasil:

Synchronizing state of cron.service with SysV service script with /lib/systemd/systemd-sysv-install.
Executing: /lib/systemd/systemd-sysv-install enable cron

Dengan berjalannya cron di background, kita sudah bisa membuat perintah secara terjadwal.

Memahami cara kerja Cron

Perintah Cron Job direkam dan dikelola oleh file spesial yang bernama "crontab". Setiap profile pengguna yang berbeda di dalam sistem dapat memiliki cron tab mereka masing-masing.

Dimana mereka dapat membuat perintah terjadwal tersendiri, yang disimpan dalam folder /var/spool/cron/crontabs/.

Membuat crontab baru

Untuk dapat menggunakan cron, kita harus login sebagai root di OS Linux atau bisa dengan pengguna biasa, namun menggunakan perintah sudo untuk dapat melakukan eksekusi sebagai root.

Ini perlu dilakukan untuk menjamin eksekusi cron job, agar tidak ada masalah permission/hak akses dikarenakan jika kita mengeksekusi perintah shell yang memerlukan level root tadi.

Lalu, ketikkan saja perintah ini di command line:

sudo crontab -u root -e

Akan terbuka file baru, jika disuruh memilih teks editor pilih saja yang nano, karena simpel dan mudah digunakan langsung di layar command line. Kemudian tambahkan perintah shell yang ingin kita jalankan secara terjadwal pada akhir baris di file ini.

Contoh di sini saya ingin mengeksekusi perintah restart untuk aplikasi flask setiap 15 menit:

*/15 * * * * sudo systemctl restart flaskproject

Untuk lengkapnya kira-kira seperti ini filenya:

# Edit this file to introduce tasks to be run by cron.
# 
# Each task to run has to be defined through a single line
# indicating with different fields when the task will be run
# and what command to run for the task
# 
# To define the time you can provide concrete values for
# minute (m), hour (h), day of month (dom), month (mon),
# and day of week (dow) or use '*' in these fields (for 'any').# 
# Notice that tasks will be started based on the cron's system
# daemon's notion of time and timezones.
# 
# Output of the crontab jobs (including errors) is sent through
# email to the user the crontab file belongs to (unless redirected).
# 
# For example, you can run a backup of all your user accounts
# at 5 a.m every week with:
# 0 5 * * 1 tar -zcf /var/backups/home.tgz /home/
# 
# For more information see the manual pages of crontab(5) and cron(8)
# 
# m h  dom mon dow   command

*/15 * * * * sudo systemctl restart flaskproject  

Save file tersebut dengan menekan tombol Ctrl + x, dan ketik y, kemudian tekan Enter.

Lalu restart linux cron servicenya dengan cara:

sudo service cron restart

Untuk memverifikasi bahwa cron telah berjalan dengan baik, bisa dengan mengetikkan perintah di bawah ini:

sudo grep -i cron /var/log/syslog|tail -3

Baiklah, itu saja tutorial cara konfigurasi Cron Job di VPS Digital Ocean OS Ubuntu 20.04. Jika ada kendala, silahkan komen di kolom komentar di bawah ini. Terima kasih telah membaca artikel ini. 😊

Rinaldi Pratama Putra
Rinaldi Pratama Putra Reality is a lovely place, but I wouldn't wanna live there.