Я запускаю программу Java в качестве демона в Linux, используя jsvc от Apache commons-daemon< /а>.
Демон «случайно» падает с одним только сообщением:
jsvc.exec error: Service did not exit cleanly
Это соответствующая часть кода в jsvc
(в jsvc-unix.c
строке 1142):
while (waitpid(pid, &status, 0) != pid) {
/* Waith for process */
}
/* The child must have exited cleanly */
if (WIFEXITED(status)) {
status = WEXITSTATUS(status);
// Clean exit code...
}
else {
if (WIFSIGNALED(status)) {
log_error("Service killed by signal %d", WTERMSIG(status));
/* prevent looping */
if (laststart + 60 > time(NULL)) {
log_debug("Waiting 60 s to prevent looping");
sleep(60);
}
continue;
}
log_error("Service did not exit cleanly", status);
return 1;
}
В каком случае WIFEXITED
и WIFSIGNALED
могут быть ложными? Гарантируется ли, что в этом случае процесс не был убит (процессом или убийцей Linux OOM)?
WIFCONTINUED(status)
) - person Karsten Koop   schedule 07.10.2016