update_daemon2: only set SIGINT handler in lock managing subprocess
This commit is contained in:
parent
c29324c7a4
commit
a65a05a72e
|
@ -61,7 +61,7 @@
|
|||
}
|
||||
|
||||
function sigalrm_handler() {
|
||||
die("received SIGALRM, hang in feed update?\n");
|
||||
die("[SIGALRM] hang in feed update?\n");
|
||||
}
|
||||
|
||||
function sigchld_handler($signal) {
|
||||
|
@ -74,12 +74,11 @@
|
|||
|
||||
function sigint_handler() {
|
||||
unlink(LOCK_DIRECTORY . "/update_daemon.lock");
|
||||
die("Received SIGINT. Exiting.\n");
|
||||
die("[SIGINT] removing lockfile and exiting.\n");
|
||||
}
|
||||
|
||||
pcntl_signal(SIGALRM, 'sigalrm_handler');
|
||||
pcntl_signal(SIGCHLD, 'sigchld_handler');
|
||||
pcntl_signal(SIGINT, 'sigint_handler');
|
||||
|
||||
if (file_is_locked("update_daemon.lock")) {
|
||||
die("error: Can't create lockfile. ".
|
||||
|
@ -92,6 +91,8 @@
|
|||
}
|
||||
|
||||
if (!pcntl_fork()) {
|
||||
pcntl_signal(SIGINT, 'sigint_handler');
|
||||
|
||||
$lock_handle = make_lockfile("update_daemon.lock");
|
||||
|
||||
if (!$lock_handle) {
|
||||
|
@ -282,7 +283,7 @@
|
|||
|
||||
if (DAEMON_SENDS_DIGESTS) send_headlines_digests($link);
|
||||
|
||||
print "Elapsed time: " . (time() - $start_timestamp) . " second(s)\n";
|
||||
_debug("Elapsed time: " . (time() - $start_timestamp) . " second(s)");
|
||||
|
||||
db_close($link);
|
||||
|
||||
|
|
Loading…
Reference in New Issue