our @EXPORT = qw(initialisation_complete);
use Carp;
-use POSIX;
use Fcntl qw(F_GETFL F_SETFL O_NONBLOCK);
+use POSIX qw(_exit setsid);
+use Sys::Syslog;
our $logger;
our @call_fds;
our $socket_path;
+sub fail ($) {
+ my ($m) = @_;
+ print STDERR "$0: prefork [$$]: $m\n";
+ flush STDERR;
+ _exit 127;
+}
+
sub server_quit ($) {
my ($m) = @_;
syslog(LOG_INFO, "$0 prefork [$$]: $m, quitting");
# Returns in the executor process
sub become_monitor () {
- my $child = fork // fail("fork executor: $!");or
+ my $child = fork // fail("fork executor: $!");
if (!$child) {
#---- executor ----
open ::STDIN , "<& $call_fds[0]" or fail("dup for fd0");
foreach (@env_params) {
$_ eq ($_+0) or croak "$env_name contains $_, not a number";
}
- open LISTEN, "<>&=$env_params[0]" or croak "listen fd: $!";
- open CALL, "<>&=$env_params[1]" or croak "listen fd: $!";
+ open LISTEN, "+>&=$env_params[0]" or croak "listen fd: $!";
+ open CALL, "+>&=$env_params[1]" or croak "listen fd: $!";
@call_fds = ($env_params[2], $env_params[3], 2);
if (!$opts{no_openlog}) {
$opts{log_facility} // 'log_user');
}
- open NULL, "<>/dev/null" or croak "open /dev/null: $!";
+ open NULL, "+>/dev/null" or croak "open /dev/null: $!";
#---- fork for server ----
my $rbits = '';
vec($rbits, fileno(LISTEN), 1) = 1;
my $ebits = $rbits;
- my $nfound = select($rbits, '', $ebits, ($opts{check_interval} // 300));
+ my $nfound = select($rbits, '', $ebits, ($opts{check_interval} // 86400));
if ($nfound) {
if (accept(CALL, LISTEN)) {