mirror of
https://github.com/xcat2/xcat-core.git
synced 2025-10-24 07:55:27 +00:00
-Have SLES plugin correctly handly ctrl-c
-Fixed problem in xcatd where stale children dying off are counted toward the wrong tallies with new aggressive loop exits git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@1140 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd
This commit is contained in:
@@ -13,6 +13,7 @@ Getopt::Long::Configure("bundling");
|
||||
Getopt::Long::Configure("pass_through");
|
||||
use File::Path;
|
||||
use File::Copy;
|
||||
my $cpiopid;
|
||||
|
||||
sub handled_commands
|
||||
{
|
||||
@@ -409,10 +410,29 @@ sub copycd
|
||||
my $omask = umask 0022;
|
||||
mkpath("$installroot/$distname/$arch/$discnumber");
|
||||
umask $omask;
|
||||
my $rc =
|
||||
system(
|
||||
"cd $path; find . | nice -n 20 cpio -dump $installroot/$distname/$arch/$discnumber/"
|
||||
);
|
||||
my $rc;
|
||||
$SIG{INT} = $SIG{TERM} = sub { if ($cpiopid) { kill 2, $cpiopid; exit 0; } };
|
||||
my $kid;
|
||||
chdir $path;
|
||||
my $child = open($kid,"|-");
|
||||
unless (defined $child) {
|
||||
$callback->({error=>"Media copy operation fork failure"});
|
||||
return;
|
||||
}
|
||||
if ($child) {
|
||||
$cpiopid = $child;
|
||||
my @finddata = `find .`;
|
||||
for (@finddata) {
|
||||
print $kid $_;
|
||||
}
|
||||
close($kid);
|
||||
$rc = $?;
|
||||
} else {
|
||||
exec "nice -n 20 cpio -dump $installroot/$distname/$arch/$discnumber/";
|
||||
}
|
||||
# system(
|
||||
# "cd $path; find . | nice -n 20 cpio -dump $installroot/$distname/$arch/$discnumber/"
|
||||
# );
|
||||
chmod 0755, "$installroot/$distname/$arch";
|
||||
chmod 0755, "$installroot/$distname/$arch/$discnumber";
|
||||
|
||||
|
@@ -14,6 +14,7 @@ use xCAT::Client submit_request;
|
||||
my $clientselect = new IO::Select;
|
||||
|
||||
my %dispatched_children;
|
||||
my %plugin_children;
|
||||
use IO::Socket::SSL;
|
||||
my $inet6support;
|
||||
$inet6support=eval { require Socket6 };
|
||||
@@ -618,7 +619,8 @@ sub plugin_command {
|
||||
}
|
||||
}
|
||||
my $children=0;
|
||||
$SIG{CHLD} = sub {while (waitpid(-1, WNOHANG) > 0) { $children--; } };
|
||||
%plugin_children=();
|
||||
$SIG{CHLD} = sub {my $plugpid; while (($plugpid = waitpid(-1, WNOHANG)) > 0) { if ($plugin_children{$plugpid}) { delete $plugin_children{$plugpid}; $children--; } } };
|
||||
my $check_fds;
|
||||
if ($sock) {
|
||||
$check_fds = new IO::Select;
|
||||
@@ -663,6 +665,7 @@ sub plugin_command {
|
||||
exit(0);
|
||||
}
|
||||
} else {
|
||||
$plugin_children{$child}=1;
|
||||
close $parfd;
|
||||
$check_fds->add($pfd);
|
||||
}
|
||||
@@ -766,6 +769,7 @@ sub relay_dispatch {
|
||||
}
|
||||
|
||||
sub dispatch_request {
|
||||
%dispatched_children=();
|
||||
my $req = shift;
|
||||
$dispatch_cb = shift;
|
||||
|
||||
@@ -782,7 +786,6 @@ sub dispatch_request {
|
||||
#Since plugins may commonly experience this, a preprocess_request implementation
|
||||
#will for now be required for a command to be scaled through service nodes
|
||||
#If the plugin offers a preprocess method, use it to set the request array
|
||||
undef $SIG{CHLD};
|
||||
if (defined(${"xCAT_plugin::".$modname."::"}{preprocess_request})) {
|
||||
$reqs = ${"xCAT_plugin::".$modname."::"}{preprocess_request}->($req,$dispatch_cb,\&do_request);
|
||||
} else { #otherwise, pass it in without hierarchy support
|
||||
@@ -790,7 +793,7 @@ sub dispatch_request {
|
||||
}
|
||||
|
||||
my $childrn=0;
|
||||
$SIG{CHLD} = sub {my $cpid; while ($cpid =waitpid(-1, WNOHANG) > 0) { delete $dispatched_children{$cpid}; $childrn--; } };
|
||||
$SIG{CHLD} = sub {my $cpid; while (($cpid =waitpid(-1, WNOHANG)) > 0) { if ($dispatched_children{$cpid}) { delete $dispatched_children{$cpid}; $childrn--; } } };
|
||||
foreach (@{$reqs}) {
|
||||
my $pfd;
|
||||
my $parfd; #use a private variable so it won't trounce itself recursively
|
||||
@@ -801,14 +804,15 @@ sub dispatch_request {
|
||||
$pfd->autoflush(1);
|
||||
$child = xCAT::Utils->xfork;
|
||||
if ($child) {
|
||||
$childrn++;
|
||||
$dispatched_children{$child}=1;
|
||||
$child_fdset->add($pfd);
|
||||
$childrn++;
|
||||
next;
|
||||
}
|
||||
unless (defined $child) {
|
||||
$dispatch_cb->({error=>['Fork failure dispatching request'],errorcode=>[1]});
|
||||
}
|
||||
undef $SIG{CHLD};
|
||||
$dispatch_parentfd = $parfd;
|
||||
if ($_->{'_xcatdest'} and thishostisnot($_->{'_xcatdest'})) {
|
||||
$ENV{XCATHOST} = ( $_->{'_xcatdest'} =~ /:/ ? $_->{'_xcatdest'} : $_->{'_xcatdest'}.":3001" );
|
||||
|
Reference in New Issue
Block a user