97 |
warn "start_stop $daemon $pid pids: ",dump( $pids ); |
warn "start_stop $daemon $pid pids: ",dump( $pids ); |
98 |
|
|
99 |
if ( $pid =~ m{^\d+$} ) { |
if ( $pid =~ m{^\d+$} ) { |
100 |
warn "kill 9 $pid"; |
my $pstree = `pstree -p $pid`; |
101 |
kill 9, $pid; |
my @pids = $pstree =~ m{\((\d+)\)}g; |
102 |
|
warn "pstree $pstree pids ",dump( @pids ); |
103 |
|
kill 1, $_ foreach reverse @pids; |
104 |
$pids->{$daemon} = 'stopped'; |
$pids->{$daemon} = 'stopped'; |
105 |
return qq|$daemon pid $pid stopped|; |
return qq|$daemon pid $pid stopped|; |
106 |
} else { |
} else { |
147 |
|
|
148 |
my $debug_proc; |
my $debug_proc; |
149 |
|
|
150 |
warn 'pids: ', dump( $pids ); |
warn 'pids: ', dump( $pids ) if $debug; |
151 |
foreach my $name ( keys %$pids ) { |
foreach my $name ( keys %$pids ) { |
152 |
my $pid = $pids->{$name} || next; |
my $pid = $pids->{$name} || next; |
153 |
|
|
167 |
push @rows, ( $name => $html ); |
push @rows, ( $name => $html ); |
168 |
} |
} |
169 |
|
|
170 |
warn 'static_pids: ', dump( $static_pids ); |
warn 'static_pids: ', dump( $static_pids ) if $debug; |
171 |
foreach my $pid ( keys %$static_pids ) { |
foreach my $pid ( keys %$static_pids ) { |
172 |
my $path = $static_pids->{$pid}; |
my $path = $static_pids->{$pid}; |
173 |
if ( -d "/proc/$pid" ) { |
if ( -d "/proc/$pid" ) { |
177 |
} |
} |
178 |
} |
} |
179 |
|
|
180 |
print $client $ok, html::table( 2, @rows ), $debug_proc; |
print $client $ok |
181 |
|
, html::table( 2, @rows ) |
182 |
|
, html::tabs( log::mac_changes ) |
183 |
|
, $debug_proc |
184 |
|
; |
185 |
|
|
186 |
} elsif ( $path =~ m{^/our/(\w+)/(\S+)} ) { |
} elsif ( $path =~ m{^/our/(\w+)/(\S+)} ) { |
187 |
eval 'our $' . $1 . ' = ' . $2; |
eval 'our $' . $1 . ' = ' . $2; |