Вход на хостинг
IT-новости
20.04.2016 iPhone 2017 года поместят в водонепроницаемый корпус из стекла
Линейка iPhone в новом году серьезно поменяется. В этом уверен аналитический исследователь Мин Чи Ку......
30.07.2015 Ищем уникальный контент для сайта
Ищем уникальный контент для сайта Без уникального контента Ваш сайт обречен на то, что его страницы......
exit if $pid;
die "Couldn’t fork: $!" unless defined($pid);
# Сохраняем PID в файл
open (F_PID, ">$pid_file") or die "Can’t open $pid_file: $!";
print F_PID "$$ ";
close F_PID;
# Перенаправляем вывод STDERR в файл
open (*STDERR, ">> $err_file") or die "Can’t reopen *STDERR to $err_file: $!";
# Перенаправляем STDIN и STDOUT в /dev/null
for my $handle (*STDIN, *STDOUT)
{
open ($handle, "> /dev/null") or die "Can’t reopen $handle to /dev/null: $!";
}
# Установка sid процесса
POSIX::setsid()
or die "Can’t start a new session: $!";
}
Чтобы обеспечить целостность данных, я установил обработчики сигналов INT и TERM. Получая один из них, программа будет пытаться немедленно записать данные в базу, если это окончится неудачей (например, сервер БД отключен), то выполнится процедура dump_to_file, которая просто запишет содержимое @log в текстовый файл. После этого работа программы будет завершена. Второй обработчик добавляет возможность записи данных в базу по сигналу HUP без выхода из программы.
$SIG{INT} = $SIG{TERM} = sub { dump_to_file if push_to_db; exit };
$SIG{HUP} = sub { dump_to_file if push_to_db };
Меняем владельца и права доступа:
# sudo chown root:gdk /usr/local/sbin/gdklogd
# sudo chmod 750 /usr/local/sbin/gdklogd
Напишем стартовый сценарий:
# vi /etc/init.d/gdklogd
#!/bin/sh
DAEMON=/usr/local/sbin/gdklogd
DAEMONFLAGS="-D"
KILL=/bin/kill
PID=/var/gdklog/gdklogd.pid
CAT=/bin/cat
SU=/bin/su
start ()
{
echo -n $"Starting $DAEMON: "
# Запуск с правами непривилегированного пользователя
$SU -c "$DAEMON $DAEMONFLAGS" gdk 2>/dev/null 1>&2
}