/[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 207 by dpavlin, Wed Aug 12 22:56:45 2009 UTC revision 390 by dpavlin, Mon Sep 7 21:34:05 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 => $$, kvm => 'not started' } 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 start_stop {  sub audit {
30            my $msg = shift;
31          my $daemon = shift;          my $daemon = shift;
32            CouchDB::audit( $msg, $daemon, { daemon => $daemon, message => $msg, @_ } );
33    }
34    
35    mkdir "$server::conf/pid" unless -d "$server::conf/pid";
36    
37    sub start_stop {
38            my ($daemon,$param) = @_;
39    
40            $daemon .= '.' . $param->{nr} if defined $param->{nr}; # XXX nr for kvm
41    
42          my $pid = $pids->{$daemon};          my $pid = $pids->{$daemon};
43          my $pid_path = "$server::conf/$daemon.pid";          my $pid_path = $daemon;
44            $pid_path =~ s{/}{-}g;
45            $pid_path = "$server::conf/pid/$pid_path";
46    
47            warn "# start_stop $daemon ",dump( $param );
48    
49          if ( ! $pid && -e $pid_path ) {          if ( ! $pid && -e $pid_path ) {
50                  my $p = read_file $pid_path;                  my $p = read_file $pid_path;
51                  if ( kill 0, $p ) {                  if ( kill 0, $p ) {
52                          warn "adopted $daemon $p\n";                          audit 'adopted', $daemon, pid => $p;
53                          return $pids->{$daemon} = $p;                          return $pids->{$daemon} = $p;
54                  } else {                  } else {
55                          warn "old $daemon $p not running";                          audit 'not running', $daemon, pid => $p;
56                          unlink $pid_path;                          unlink $pid_path;
57                  }                  }
58          }          }
# Line 41  sub start_stop { Line 60  sub start_stop {
60          $pid ||= 'not started';          $pid ||= 'not started';
61          warn "start_stop $daemon $pid\n";          warn "start_stop $daemon $pid\n";
62    
63          if ( $pid =~ m{^\d+$} ) {          if ( $pid =~ m{^\d+$} && kill 0, $pid ) {
64                  my $pstree = `pstree -p $pid`;                  my $pstree = `pstree -p $pid`;
65                  my @pids = $pstree =~ m{\((\d+)\)}g;                  my @pids = $pstree =~ m{\((\d+)\)}g;
66                  warn "pstree $pstree pids ",dump( @pids );                  warn "pstree $pstree pids ",dump( @pids );
67                  kill 1, $_ foreach reverse @pids;                  foreach ( @pids ) {
68                            warn "kill $_\n";
69                            kill 1, $_;
70                            if ( kill 0, $_ ) {
71                                    warn "kill 9 $_";
72                                    kill 9, $_;
73                            }
74                    }
75                  $pids->{$daemon} = 'stopped';                  $pids->{$daemon} = 'stopped';
76                    audit 'stopped', $daemon, pid => $pid;
77                  return qq|$daemon pid $pid stopped|;                  return qq|$daemon pid $pid stopped|;
78          } else {          } else {
79    
80                    $ENV{$_} = $param->{$_} foreach keys %$param;
81    
82                  if ( $pid = fork ) {                  if ( $pid = fork ) {
83                          # parent                          # parent
84                          $pids->{$daemon} = $pid;                          $pids->{$daemon} = $pid;
85                          write_file $pid_path, $pid;                          write_file $pid_path, $pid;
86                          warn "forked $daemon $pid\n";                          audit 'forked', $daemon, pid => $pid;
87    
88                            delete $ENV{$_} foreach keys %$param; # cleanup enviroment
89    
90                          return qq|$daemon pid $pid started|;                          return qq|$daemon pid $pid started|;
91                  } elsif ( defined $pid ) {                  } elsif ( defined $pid ) {
92                          # child                          # child
93                          my $invoke = 'start';                          my $invoke = 'start';
94                          $invoke = $1 if $daemon =~ s{/(.+)}{};                          $invoke = $1 if $daemon =~ s{/(.+)}{};
95                          if ( $daemon =~ m{dhcpd|tftpd|dnsd} ) {  warn "XXX child ",dump( %ENV );
96                            if ( $daemon =~ m{dhcpd|tftpd|dnsd|syslogd} ) {
97                                  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}";
98                                  warn "exec $exec";                                  audit 'exec', $daemon, 'exec' => $exec;
99                                  x11::xterm( $daemon => $exec );                                  x11::xterm( $daemon => $exec );
100                          } else {                          } else {
101                                  my $eval = $daemon . '::' . $invoke . '(' . ( @_ ? dump(@_) : '' ) . ')';                                  $daemon =~ s{\.\d+$}{} if defined $ENV{nr};
102                                  warn "eval $eval";  warn "XXXX $daemon\n";
103                                    my $eval = $daemon . '::' . $invoke . '(' . dump( $param ) . ')';
104                                    audit 'eval', $daemon, 'eval' => $eval;
105                                  eval $eval;                                  eval $eval;
106                                  warn "can't start $daemon: $@" if $@;                                  audit 'error', $daemon, error => $@  if $@;
107                          }                          }
108                          exit;                          exit;
109                  } else {                  } else {
110                            audit 'error', $daemon, error => $!;
111                          die "fork error $!";                          die "fork error $!";
112                  }                  }
113          }          }

Legend:
Removed from v.207  
changed lines
  Added in v.390

  ViewVC Help
Powered by ViewVC 1.1.26