У меня есть сценарий оболочки, который, по сути, представляет собой одну строку с некоторыми журналами, которые я пытаюсь запустить из сценария инициализации. Я использую daemon
функцию внутри, /etc/init.d/functions
чтобы запустить его, так как Redhat, кажется, не start-stop-daemon
доступен. Когда я вызываю скрипт init ( /etc/init.d/script start
), он остается на переднем плане, а не завершает и оставляет процесс запущенным. Как мне правильно сделать этот скрипт демонизированным?
Скрипт для запуска:
# conf file where variables are defined
. /etc/script.conf
echo "Starting..." | logger -i
echo "Monitoring $LOG_LOCATION." | logger -i
echo "Sending to $MONITOR_HOST:$MONITOR_PORT." | logger -i
tail -n 1 -F $LOG_LOCATION |
grep WARN --line-buffered |
/usr/bin/nc -vv $MONITOR_HOST $MONITOR_PORT 2>&1 |
logger -i
сценарий инициализации:
#!/bin/bash
# Source Defaults
. /etc/default/script
# Source init functions
. /etc/init.d/functions
prog=/usr/local/bin/script.sh
[ -f /etc/script.conf ] || exit 1
RETVAL=0
start()
{
# Quit if disabled
if ! $ENABLED; then
echo "Service Disabled in /etc/default/script"
exit 1
fi
echo "Starting $prog"
daemon $prog
RETVAL=$?
return $RETVAL
}
stop ()
{
echo -n $"Stopping $prog: "
killproc $prog
RETVAL=$?
return $RETVAL
}
reload()
{
echo "Reload command is not implemented for this service."
return $RETVAL
}
restart()
{
stop
start
}
condrestart()
{
echo "Not Implemented."
}
# See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status $prog
;;
restart)
restart
;;
reload)
reload
;;
condrestart)
condrestart
;;
*)
echo $"Usage: $0 {start|stop|status|restart|condrestart|reload}"
RETVAL=1
esac
Последние ~ 20 строк исполнения с bash -vx:
+ case "$1" in
+ start
+ true
+ echo 'Starting /usr/local/bin/script.sh'
Starting /usr/local/bin/script.sh
+ daemon /usr/local/bin/script.sh
+ local gotbase= force=
+ local base= user= nice= bg= pid=
+ nicelevel=0
+ '[' /usr/local/bin/script.sh '!=' /usr/local/bin/script.sh ']'
+ '[' -z '' ']'
+ base=script.sh
+ '[' -f /var/run/script.sh.pid ']'
+ '[' -n '' -a -z '' ']'
+ ulimit -S -c 0
+ '[' -n '' ']'
+ '[' color = verbose -a -z '' ']'
+ '[' -z '' ']'
+ initlog -q -c /usr/local/bin/script.sh
shell-script
rhel
init-script
bshacklett
источник
источник
bash -vx ...
и опубликовали последние строки, чтобы мы могли увидеть, что остается на переднем плане.daemon
, есть также пакет RPM . Кстати, есть много инструментов мониторинга журналов ( начните здесь ).#!/bin/bash -vx
? Я попытался сделать это, но он не выдал тот же вывод из скрипта инициализации, как если бы я запустил скрипт оболочки напрямую.bash -vx
, т.е.bash -vx /etc/init.d/script start
,Ответы:
Я нашел скрипт на http://www.linuxforums.org/forum/programming-scripting/190279-daemon-etc-init-d-functions-does-not-return-launching-process.html#post897522, который мне удалось изменить в соответствии с моими потребностями. Он вручную отслеживает PID и создает файл PID, используя
pidof
. Мне пришлось изменить это для использования, такpgrep
какpidof
не смог увидеть PID моего скрипта. После этой модификации все заработало нормально. * Обратите внимание, pgrep работает только в том случае, если полное имя скрипта менее 15 символовВот чем я закончил:
источник
Я не знаю Redhat, но
daemon $prog &
выглядит странно для меня. Если уже есть функция для демонизации, почему необходимо (и полезно) поместить эту функцию в фоновый режим? Таким образом, попробуйте без&
.источник
/etc/init.d/functions
определяетdaemon
функцию, которая ожидает, что ее аргумент демонизирует себя, она заботится только о таких вещах, как смена пользователя, установка ulimits, проверка (не создание!) файла pid ... Лучшее использование этойdaemon
функции - заменить ее на libslackdaemon
;)