Leser: 3
5 Einträge, 1 Seite |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
local $SIG{HUP} = 'IGNORE';
$SIG{HUP} = \&SIGKILL_handler;
while ( $#todo >= 0 && $result == 0) {
last if($result > 0);
my $cmd = pop(@todo);
$sem->down(); # nur n Tasks gleichzeitig
if ( $result == 0) {
my $thread = threads->new(
\&Task,
$cmd, # neuen Thread erzeugen
);
}
}
#-------------------------------------------------------------------------
sub Task {
my (
$cmd, # Parameter
) = @_;
my $id = threads->self->tid;
$thread_run++;
$result += system ($cmd)/256;;
if ($debug == 1) { print " Return: $result \n\n"; }
$sem->up();
$thread_run--;
printf "Thread %02d: fertig.\n", $id;
if ($result >0){print "\n\n Fehler !!!!!!!!\n\n";
kill ("HUP", -$$);
}
}
#-------------------------------------------------------------------------
sub SIGKILL_handler {
print "SIG_KILL\n";
kill ("HUP", -$$);
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
#!/usr/bin/perl use strict; use warnings; use POSIX ':sys_wait_h'; my $anzahl=5; my @kinder=map{$_=0}(0..$anzahl); my $cmd="sh -c 'sleep %u'"; sub ende() { $SIG{CHLD}='IGNORE'; kill(9,grep{$_>0}@kinder); exit; } $SIG{INT}=\&ende; $SIG{HUP}=\&ende; $SIG{QUIT}=\&ende; sub watch_childs() { for my $pid (@kinder) { if($pid!=0) { if(waitpid( $pid, WNOHANG )==$pid) { print "Prozess $pid beendet"; $pid=0; my $status=$?/256; if($status!=0) { print " aber ein Fehler ist aufgetreten! ($status)\n"; $SIG{CHLD}='IGNORE'; kill(9,grep{$_>0}@kinder); die "Beende mich wegen Fehler in einem Kindprozess ($pid)!\n"; } else { print " und kein Fehler ist aufgetreten.\n"; } } else { print "Prozess $pid läuft noch\n"; } } } } $SIG{CHLD}=\&watch_childs; my $cnt=0; for my $pid (@kinder) { $cnt++; $pid=fork(); exec(sprintf($cmd,$cnt*2)) unless($pid); } # mach was anderes... while(waitpid( -1, WNOHANG ) != -1) { sleep(3); print "Warte\n"; }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
#!/usr/bin/perl use strict; use warnings; use POSIX ':sys_wait_h'; my $anzahl=5; my @kinder=map{$_=0}(0..$anzahl); my @cmds=("sleep 20", "sleep 10", "sleep 30", "sleep 10", "sleep 20", "sleep 30", "sleep 20", "sleep 10", "sleep 30", "sleep 10", "sleep 20", "sleep 30", "sleep 20", "sleep 10", "sleep 30"); sub ende() { $SIG{CHLD}='IGNORE'; kill(9,grep{$_>0}@kinder); exit; } $SIG{INT}=\&ende; $SIG{HUP}=\&ende; $SIG{QUIT}=\&ende; sub watch_childs() { for my $pid (grep{$_>0}@kinder) { if(waitpid( $pid, WNOHANG )==$pid) { print "Prozess $pid beendet"; my $status=$?/256; if($status!=0) { print " aber ein Fehler ist aufgetreten! ($?)\n"; $SIG{CHLD}='IGNORE'; kill(9,grep{$_>0}@kinder); die "Beende mich wegen Fehler in einem Kindprozess ($pid)!\n"; } else { print " und kein Fehler ist aufgetreten.\n"; } # nächsten Befehl staren $pid=0; if(@cmds) { my $cmd=shift(@cmds); $pid=fork(); exec($cmd) unless($pid); } } } } $SIG{CHLD}=\&watch_childs; for my $pid (@kinder) { my $cmd=shift(@cmds); $pid=fork(); exec($cmd) unless($pid); } # mach was anderes... my $ex=1; while($ex) { sleep(3); $ex=0; for my $pid (grep{$_>0}@kinder) { if(kill(0,$pid)) { print "Prozess $pid läuft noch. \n"; $ex=1; } } print "Es warten noch ".@cmds." Befehle auf Ausführung.\n"; }
5 Einträge, 1 Seite |