При запуске и остановке служб на сервере вызывается скрипт /app/xge/cfg/hooks с параметрами, сообщающими о том, какая служба была запущена или остановлена. Первый параметр - служба, второй 'start' или 'stop' (кроме службы firewall.sh), третий параметр - код возврата от службы.
При помощи файла /app/xge/cfg/hooks можно делать нестандартные настройки сервера.
В этом разделе приводятся примеры таких скриптов.
Отредактировать файл можно следуя инструкциям из этой статьи.
Изменения вносятся в середину скрипта, первую и последнюю строки оставьте неизменными. В общем виде скрипт должен выглядеть так.
#!/bin/bash if [ "$1" = 'Имя_службы' ]; then : #Ваши изменения здесь fi exit 0
либо так
#!/bin/bash if [ "$1" = 'Имя_службы' -a "$2" = 'Параметр' ]; then : #Ваши изменения здесь fi exit 0
Пример. Проброс telnet в xge
#!/bin/bash if [ "$1" = "/etc/init.d/firewall" ]; then iptables -t nat -I xge_pre -d 192.168.245.1 -p tcp --dport 23 -j DNAT --to-destination 192.168.1.3:23 fi
Автоматизированное использование
Ничто не мешает использовать hooks с помощью cron. Таким образом вы можете выполнять некие команды не при наступлении какого-то события, а в нужное вам время.
Для этого нужно использовать в качестве имени службы:
- cron.10min - для того чтобы выполнять что-то каждые 10 минут
- cron.daily - для того чтобы выполнять что-то каждый день
- cron.hourly - для того чтобы выполнять что-то каждый час
- cron.monthly - для того чтобы выполнять что-то каждый месяц
- cron.weekly - для того чтобы выполнять что-то каждую неделю
Либо /etc/crontab, если вам нужно указать специфичное время, но в таком случае указать в вызове в качестве имени службы что-то уникальное, например
10 */2 * * * root /cfg/hooks /etc/init.d/networkd start 1>/dev/null 2>/dev/null