/[pxelator]/lib/PXElator/daemons.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /lib/PXElator/daemons.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 185 by dpavlin, Sun Aug 9 21:13:36 2009 UTC revision 245 by dpavlin, Mon Aug 17 15:14:58 2009 UTC
# Line 7  use File::Slurp; Line 7  use File::Slurp;
7  use Data::Dump qw/dump/;  use Data::Dump qw/dump/;
8    
9  use x11;  use x11;
10    use CouchDB;
11    
12  our $pids;  our $pids;
13  $pids = { httpd => $$ } unless defined $pids; # keep pids on refresh  $pids = {
14            httpd => $$,
15            kvm => 'not started',
16            wireshark => 'not started',
17    } unless defined $pids; # keep pids on refresh
18    
19  sub DESTROY {  sub DESTROY {
20          warn "pids ",dump( $pids );          warn "pids ",dump( $pids );
# Line 21  sub DESTROY { Line 26  sub DESTROY {
26    
27  $SIG{CHLD} = 'IGNORE';  $SIG{CHLD} = 'IGNORE';
28    
29    sub audit {
30            my $msg = shift;
31            my $daemon = shift;
32            CouchDB::audit( $msg, $daemon, { daemon => $daemon, message => $msg, @_ } );
33    }
34    
35  sub start_stop {  sub start_stop {
36          my $daemon = shift;          my $daemon = shift;
37    
38          my $pid = $pids->{$daemon};          my $pid = $pids->{$daemon};
39          my $pid_path = "$server::conf/$daemon.pid";          my $pid_path = "$daemon.pid";
40            $pid_path =~ s{/}{-}g;
41            $pid_path = "$server::conf/$pid_path";
42    
43          if ( ! $pid && -e $pid_path ) {          if ( ! $pid && -e $pid_path ) {
44                  my $p = read_file $pid_path;                  my $p = read_file $pid_path;
45                  if ( kill 0, $p ) {                  if ( kill 0, $p ) {
46                          warn "adopted $daemon $p\n";                          audit 'adopted', $daemon, pid => $p;
47                          return $pids->{$daemon} = $p;                          return $pids->{$daemon} = $p;
48                  } else {                  } else {
49                          warn "old $daemon $p not running";                          audit 'not running', $daemon, pid => $p;
50                          unlink $pid_path;                          unlink $pid_path;
51                  }                  }
52          }          }
# Line 41  sub start_stop { Line 54  sub start_stop {
54          $pid ||= 'not started';          $pid ||= 'not started';
55          warn "start_stop $daemon $pid\n";          warn "start_stop $daemon $pid\n";
56    
57          if ( $pid =~ m{^\d+$} ) {          if ( $pid =~ m{^\d+$} && kill 0, $pid ) {
58                  my $pstree = `pstree -p $pid`;                  my $pstree = `pstree -p $pid`;
59                  my @pids = $pstree =~ m{\((\d+)\)}g;                  my @pids = $pstree =~ m{\((\d+)\)}g;
60                  warn "pstree $pstree pids ",dump( @pids );                  warn "pstree $pstree pids ",dump( @pids );
61                  kill 1, $_ foreach reverse @pids;                  foreach ( @pids ) {
62                            warn "kill $_\n";
63                            kill 1, $_;
64                            if ( kill 0, $_ ) {
65                                    warn "kill 9 $_";
66                                    kill 9, $_;
67                            }
68                    }
69                  $pids->{$daemon} = 'stopped';                  $pids->{$daemon} = 'stopped';
70                    audit 'stopped', $daemon, pid => $pid;
71                  return qq|$daemon pid $pid stopped|;                  return qq|$daemon pid $pid stopped|;
72          } else {          } else {
73                  if ( $pid = fork ) {                  if ( $pid = fork ) {
74                          # parent                          # parent
75                          $pids->{$daemon} = $pid;                          $pids->{$daemon} = $pid;
76                          write_file $pid_path, $pid;                          write_file $pid_path, $pid;
77                          warn "forked $daemon $pid\n";                          audit 'forked', $daemon, pid => $pid;
78                          return qq|$daemon pid $pid started|;                          return qq|$daemon pid $pid started|;
79                  } elsif ( defined $pid ) {                  } elsif ( defined $pid ) {
80                          # child                          # child
81                          my $invoke = 'start';                          my $invoke = 'start';
82                          $invoke = $1 if $daemon =~ s{/(.+)}{};                          $invoke = $1 if $daemon =~ s{/(.+)}{};
83                          if ( $daemon =~ m{dhcpd|tftpd|dnsd} ) {                          if ( $daemon =~ m{dhcpd|tftpd|dnsd|syslogd} ) {
84                                  my $exec = "perl -I$server::base_dir/lib -I$server::base_dir/lib/PXElator -M$daemon -e ${daemon}::${invoke}";                                  my $exec = "perl -I$server::base_dir/lib -I$server::base_dir/lib/PXElator -M$daemon -e ${daemon}::${invoke}";
85                                  warn "exec $exec";                                  audit 'exec', $daemon, 'exec' => $exec;
86                                  x11::xterm( $daemon => $exec );                                  x11::xterm( $daemon => $exec );
87                          } else {                          } else {
88                                  my $eval = $daemon . '::' . $invoke . '(' . ( @_ ? dump(@_) : '' ) . ')';                                  my $eval = $daemon . '::' . $invoke . '(' . ( @_ ? dump(@_) : '' ) . ')';
89                                  warn "eval $eval";                                  audit 'eval', $daemon, 'eval' => $eval;
90                                  eval $eval;                                  eval $eval;
91                                  warn "can't start $daemon: $@" if $@;                                  audit 'error', $daemon, error => $@  if $@;
92                          }                          }
93                          exit;                          exit;
94                  } else {                  } else {
95                            audit 'error', $daemon, error => $!;
96                          die "fork error $!";                          die "fork error $!";
97                  }                  }
98          }          }

Legend:
Removed from v.185  
changed lines
  Added in v.245

  ViewVC Help
Powered by ViewVC 1.1.26