Panduan ini menunjukkan bagaimana Anda dapat menginstal dan menggunakan incron pada sistem Debian Etch. Incron mirip dengan cron, tetapi alih-alih menjalankan perintah berdasarkan waktu, Incron dapat memicu perintah ketika peristiwa file atau direktori terjadi (misalnya, modifikasi file, perubahan izin, dll.).
Dokumen ini datang tanpa jaminan apapun! Saya tidak memberikan jaminan apa pun bahwa ini akan berhasil untuk Anda!
1 Memasang Incron
Incron tersedia di repositori etch-backports, jadi kita harus menambahkan baris berikut ke /etc/apt/sources.list:
vi /etc/apt/sources.list
[...]deb http://www.backports.org/debian etch-backports kontribusi utama tidak bebas[...] |
Mari impor kunci arsip backports.org ke apt...
wget -O - http://backports.org/debian/archive.key | apt-key tambahkan -
... dan jalankan
apt-get update
Repositori etch-backports tidak aktif secara default, jadi untuk menginstal incron darinya, kita harus menggunakan perintah berikut:
apt-get -t etch-backports install incron
2 Menggunakan Incron
Penggunaan Incron sangat mirip dengan penggunaan cron. Anda memiliki perintah incrontab yang memungkinkan Anda membuat daftar (-l), mengedit (-e), dan menghapus (-r) entri incrontab. Untuk mempelajari lebih lanjut tentangnya, lihat
man incrontab
Di sana Anda juga menemukan bagian berikut:
Jika /etc/incron.allow ada, hanya pengguna yang terdaftar di sini yang dapat menggunakan incron. Jika tidak, jika /etc/incron.deny ada, hanya pengguna yang TIDAK terdaftar di sini yang dapat menggunakan incron. Jika tidak ada file ini, semua orang diizinkan untuk menggunakan incron. (Catatan penting:Perilaku ini tidak aman dan mungkin akan diubah agar kompatibel dengan gaya yang digunakan oleh ISC Cron.) Lokasi file ini dapat diubah dalam konfigurasi.
Ini berarti jika kita ingin menggunakan incrontab sebagai root, kita harus menghapus /etc/incron.allow (yang tidak aman karena setiap pengguna sistem dapat menggunakan incrontab)...
rm -f /etc/incron.allow
... atau tambahkan root ke file itu (disarankan):
vi /etc/incron.allow
root |
Sebelum Anda melakukan ini, Anda akan mendapatkan pesan kesalahan seperti ini saat mencoba menggunakan incrontab:
server1:~# incrontab -l
pengguna 'root' tidak diperbolehkan menggunakan incron
server1:~#
Setelah itu berfungsi:
server1:~# incrontab -l
tidak ada tabel untuk root
server1:~#
Kita bisa menggunakan
incrontab -e
untuk menciptakan pekerjaan incron. Sebelum kita melakukan ini, kita lihat di
man 5 incrontab
karena menjelaskan format crontab. Pada dasarnya formatnya adalah sebagai berikut...
...di mana
IN_ACCESS File telah diakses (baca) (*)
IN_ATTRIB Metadata diubah (permissions, timestamps, extended attributes, dll.) (*)
IN_CLOSE_NOWRITE File tidak dibuka untuk menulis telah ditutup (*)
IN_CREATE File/direktori dibuat di watched directory (*)
IN_DELETE direktori diletkan file /indirectory itu sendiri dihapus
IN_MODIFY File telah dimodifikasi (*)
IN_MOVE_SELF Watched file/directory itu sendiri dipindahkan
IN_MOVED_FROM dipindahkan ke keluar direktori yang ditonton (*)
IN_OPEN File dibuka (*)
Saat memantau direktori, peristiwa yang ditandai dengan tanda bintang (*) di atas dapat terjadi untuk file dalam direktori, dalam hal ini bidang nama di
data peristiwa yang dikembalikan mengidentifikasi nama file di dalam direktori.
Simbol IN_ALL_EVENTS didefinisikan sebagai topeng bit dari semua kejadian di atas. Dua simbol kenyamanan tambahan adalah IN_MOVE, yang merupakan kombinasi dari IN_MOVED_FROM dan IN_MOVED_TO, dan IN_CLOSE yang menggabungkan IN_CLOSE_WRITE dan IN_CLOSE_NOWRITE.
Simbol lebih lanjut berikut dapat ditentukan dalam topeng:
IN_DONT_FOLLOW Jangan mereferensikan nama jalur jika itu adalah tautan simbolis
IN_ONESHOT Monitor nama jalur untuk hanya satu peristiwa
IN_ONLYDIR directorypath jika nama jalur tontonan sajaSelain itu, ada simbol yang tidak muncul di kumpulan simbol inotify. Ini adalah IN_NO_LOOP. Simbol ini menonaktifkan pemantauan peristiwa hingga peristiwa saat ini sepenuhnya ditangani (sampai proses turunannya keluar).
adalah perintah yang harus dijalankan saat event terjadi. Wildard berikut dapat digunakan di dalam spesifikasi perintah: $$ tanda dolar
[dilindungi email] jalur sistem file yang diawasi (lihat di atas)
$# nama file yang terkait dengan peristiwa
$% tanda peristiwa (secara tekstual)
$&tanda peristiwa (secara numerik)Jika Anda menonton sebuah direktori, [email protected] akan menyimpan jalur direktori dan $# file yang memicu peristiwa tersebut. Jika Anda menonton file, [email protected] menyimpan jalur lengkap ke file tersebut dan $# kosong.
Jika Anda memerlukan wildcard tetapi tidak yakin dengan apa terjemahannya, Anda dapat membuat tugas incron seperti ini:
/tmp/ IN_MODIFY echo "$$ [email protected] $# $% $&" |
Kemudian Anda membuat atau memodifikasi file di direktori /tmp dan lihat /var/log/syslog - log ini menunjukkan kapan tugas incron dipicu, jika berhasil atau jika ada kesalahan, dan apa perintah sebenarnya itu itu dieksekusi (yaitu, wildcard diganti dengan nilai sebenarnya).
ekor /var/log/syslog
...
21 Agustus 17:26:50 server1 incrond[7111]:(root) CMD (echo "$ /tmp huhu IN_CREATE 256")
Dalam contoh ini saya telah membuat file /tmp/huhu; seperti yang Anda lihat [email protected] diterjemahkan menjadi /tmp, $# menjadi huhu, $% menjadi IN_CREATE, dan $&menjadi 256.
Sekarang cukup teori. Mari kita buat pekerjaan incron pertama kita. Saya ingin memantau file /etc/apache2/apache2.conf dan direktori /etc/apache2/vhosts/, dan setiap kali ada perubahan, saya ingin incron me-restart Apache. Beginilah cara kami melakukannya:
incrontab -e
/etc/apache2/apache2.conf IN_MODIFY /etc/init.d/apache2 restart/etc/apache2/vhosts/ IN_MODIFY /etc/init. d/apache2 mulai ulang |
Itu dia. Untuk tujuan pengujian, Anda dapat memodifikasi konfigurasi Apache dan melihat /var/log/syslog, dan Anda akan melihat bahwa incron memulai ulang Apache.
Untuk membuat daftar semua tugas incron yang ditentukan, Anda dapat menjalankan
incrontab -l
server1:~# incrontab -l
/etc/apache2/apache2.conf IN_MODIFY /etc/init.d/apache2 restart
/etc/apache2/vhosts/ IN_MODIFY /etc/init.d /apache2 restart
server1:~#
Untuk menghapus semua tugas incron dari pengguna saat ini, jalankan
incrontab -r
server1:~# incrontab -r
menghapus tabel untuk 'root' pengguna
tabel untuk 'root' pengguna berhasil dihapus
server1:~#
3 Tautan
- incron:http://inotify.aiken.cz/?section=incron&page=about&lang=en