Перейти до змісту

Компіляція та інсталяція

Виконайте наступні операції на сервері. У вашому середовищі можуть бути відсутні деякі залежні пакунки. Встановіть їх за допомогою: dnf -y install autoconf automake libtool

[root@Rocky ~]# wget -c https://github.com/inotify-tools/inotify-tools/archive/refs/tags/3.21.9.6.tar.gz
[root@Rocky ~]# tar -zvxf 3.21.9.6.tar.gz -C /usr/local/src/
[root@Rocky ~]# cd /usr/local/src/inotify-tools-3.21.9.6/
[root@Rocky /usr/local/src/inotify-tools-3.21.9.6]# ./autogen.sh && \
./configure --prefix=/usr/local/inotify-tools && \
make && \
make install
...
[root@Rocky ~]# ls /usr/local/inotify-tools/bin/
inotifywait inotifywatch

Додайте змінну середовища PATH, запишіть її у файл конфігурації та залиште її діяти постійно.

[root@Rocky ~]# vim /etc/profile
...
PATH=$PATH:/usr/local/inotify-tools/bin/
[root@Rocky ~]# . /etc/profile

Чому б не використати пакет RPM inotify-tools зі сховища EPEL? А як використовувати вихідний код для компіляції та встановлення?

Автор особисто вважає, що віддалена передача даних є питанням ефективності, особливо у виробничому середовищі, де існує велика кількість файлів, які потрібно синхронізувати, і один файл є особливо великим. Крім того, у новій версії буде виправлено деякі помилки та розширено функції, і, можливо, ефективність передачі нової версії буде вищою, тому я рекомендую встановлювати inotify-tools за вихідним кодом. Звичайно, це особиста пропозиція автора, не кожен користувач повинен її дотримуватися.

Налаштування параметрів ядра

Ви можете налаштувати параметри ядра відповідно до потреб виробничого середовища. За замовчуванням у /proc/sys/fs/inotity/ є три файли

[root@Rocky ~]# cd /proc/sys/fs/inotify/
[root@Rocky /proc/sys/fs/inotify]# cat max_queued_events ;cat max_user_instances ;cat max_user_watches
16384
128
28014
  • max_queued_events-maximum розмір черги монітора, за замовчуванням 16384
  • max_user_instances-the - максимальна кількість екземплярів моніторингу, за замовчуванням 128
  • max_user_watches-the максимальна кількість файлів, що відстежуються на екземпляр, за замовчуванням 8192

Запишіть деякі параметри та значення в /etc/sysctl.conf, приклади наведені нижче. Потім скористайтеся sysctl -p, щоб файли набули чинності

fs.inotify.max_queued_events = 16384
fs.inotify.max_user_instances = 1024
fs.inotify.max_user_watches = 1048576

Пов'язані команди

Інструмент inotify-tools має дві команди, а саме:

  • inotifywait: для безперервного моніторингу, результати виведення в реальному часі. Зазвичай він використовується з інструментом інкрементального резервного копіювання rsync. Оскільки це моніторинг файлової системи, його можна використовувати зі сценарієм. Конкретний сценарій ми представимо пізніше.

  • inotifywatch: виведення результатів після виконання завдання для короткочасного моніторингу.

inotifywait переважно має наступні параметри:

-m означає постійний моніторинг
-r Рекурсивний моніторинг
-q Спростити вихідну інформацію
-e вказує тип події даних моніторингу, кілька типів подій розділяються комами в статусі англійською мовою

Типи подій:

Тип подіїОпис
accessДоступ до вмісту файлу або каталогу
modifyЗаписується вміст файлу або каталогу
attribАтрибути файлу або каталогу змінено
close_writeФайл або каталог відкривається в режимі запису, а потім закривається
close_nowriteФайл або каталог закриваються після відкриття в режимі лише для читання
closeНезалежно від режиму читання/запису, файл або каталог закриваються
openФайл або каталог відкрито
moved_toФайл або каталог переміщується до контрольованого каталогу
moved_fromФайл або каталог переміщено з контрольованого каталогу
moveЄ файли або каталоги, які переміщуються до або видаляються з каталогу моніторингу
move_selfКонтрольований файл або каталог було переміщено
createУ контрольованому каталозі створено файли або каталоги
deleteФайл або каталог у контрольованому каталозі видалено
delete_selfФайл або каталог видалено
unmountФайлова система, що містить немонтовані файли або каталоги

Приклад: [root@Rocky ~]# inotifywait -mrq -e create,delete /rsync/

Демонстрація команди inotifywait

Введіть команду в перший термінал pts/0, і після натискання Enter вікно заблокується, вказуючи на те, що здійснюється моніторинг

[root@Rocky ~]# inotifywait -mrq -e create,delete /rsync/

У другому терміналі pts/1 перейдіть до каталогу /rsync/ і створіть файл.

[root@Rocky ~]# cd /rsync/
[root@Rocky /rsync]# touch inotify

Повернемося до першого терміналу pts/0, вихідна інформація така:

[root@Rocky ~]# inotifywait -mrq -e create,delete /rsync/
/rsync/ CREATE inotify

Поєднання inotifywait і rsync

Підказка

Ми працюємо на сервері Rocky Linux 8, використовуючи для демонстрації протокол SSH.

Для входу без пароля для автентифікації протоколу SSH зверніться до rsync для входу без пароля, який тут не описано. Нижче наведено приклад вмісту сценарію bash. Ви можете додати різні параметри після команди відповідно до ваших потреб. Наприклад, ви також можете додати --delete після команди rsync.

#!/bin/bash
a="/usr/local/inotify-tools/bin/inotifywait -mrq -e modify,move,create,delete /rsync/"
b="/usr/bin/rsync -avz /rsync/* testfedora@192.168.100.5:/home/testfedora/"
$a | while read directory event file
    do
        $b &>> /tmp/rsync.log
    done
[root@Rocky ~]# chmod +x rsync_inotify.sh
[root@Rocky ~]# bash /root/rsync_inotify.sh &

Підказка

Під час використання протоколу SSH для передачі даних синхронізації, якщо порт служби SSH цільової машини не 22, ви можете використовувати метод, подібний до цього—— b="/usr/bin/rsync -avz -e 'ssh -p [port-number]' /rsync/* testfedora@192.168.100.5:/home/testfedora/"

Підказка

Якщо ви хочете запустити цей сценарій під час завантаження [root@Rocky ~]# echo "bash /root/rsync_inotify.sh &" >> /etc/rc.local [root@Rocky ~]# chmod +x /etc/rc.local

Якщо ви використовуєте протокол rsync для синхронізації, вам потрібно налаштувати службу rsync цільової машини, будь ласка, зверніться до demo rsync 02, файл конфігурації rsync, rsync free Secret authentication login

Author: tianci li

Contributors: Steven Spencer, Ganna Zhyrnova