From 8a04a0ce4044156cff91eb7245dedbb94344e86b Mon Sep 17 00:00:00 2001 From: jbjohnso Date: Wed, 22 Jun 2011 15:23:06 +0000 Subject: [PATCH] -Reduce kvm supervisory process load by stopping what amounts to a busy wait when child is done sending messages up -Eliminate call to create a new vm table object in kvm.pm, when it's usually not needed, move to create only when needed. git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@9896 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd --- xCAT-server/lib/xcat/plugins/kvm.pm | 26 +++++++++++++++----------- 1 file changed, 15 insertions(+), 11 deletions(-) diff --git a/xCAT-server/lib/xcat/plugins/kvm.pm b/xCAT-server/lib/xcat/plugins/kvm.pm index db1b14e0a..256b31039 100644 --- a/xCAT-server/lib/xcat/plugins/kvm.pm +++ b/xCAT-server/lib/xcat/plugins/kvm.pm @@ -905,6 +905,7 @@ sub migrate { close($sock); if ($desthypconn->get_domain_by_name($node)) { #$updatetable->{vm}->{$node}->{host} = $targ; + unless ($vmtab) { $vmtab = new xCAT::Table('vm',-create=>1); } $vmtab->setNodeAttribs($node,{host=>$targ}); return (0,"migrated to $targ"); } else { #This *should* not be possible @@ -2308,6 +2309,7 @@ sub adopt { delete $orphash->{$node}; $vmupdates->{$node}->{host}=$target; } + unless ($vmtab) { $vmtab = new xCAT::Table('vm',-create=>1); } $vmtab->setNodesAttribs($vmupdates); if (keys %{$orphash}) { return 0; @@ -2656,7 +2658,7 @@ sub process_request { close ($pfd); $sub_fds->add($cfd); } - while ($sub_fds->count > 0 or $children > 0) { + while ($sub_fds->count > 0) { # or $children > 0) { #if count is zero, even if we have live children, we can't possibly get data from them my $handlednodes={}; forward_data($callback,$sub_fds,$handlednodes); #update the node status to the nodelist.status table @@ -2664,17 +2666,18 @@ sub process_request { updateNodeStatus($handlednodes, \@allerrornodes); } } + #while (wait() > -1) { } #keep around just in case we find the absolute need to wait for children to be gone #Make sure they get drained, this probably is overkill but shouldn't hurt - my $rc=1; - while ( $rc>0 ) { - my $handlednodes={}; - $rc=forward_data($callback,$sub_fds,$handlednodes); - #update the node status to the nodelist.status table - if ($check) { - updateNodeStatus($handlednodes, \@allerrornodes); - } - } + #my $rc=1; + #while ( $rc>0 ) { + # my $handlednodes={}; + # $rc=forward_data($callback,$sub_fds,$handlednodes); + # #update the node status to the nodelist.status table + # if ($check) { + # updateNodeStatus($handlednodes, \@allerrornodes); + # } + #} if ($check) { #print "allerrornodes=@allerrornodes\n"; @@ -2756,7 +2759,8 @@ sub dohyp { my @exargs=@{$namedargs{-args}}; my $node; my $args = \@exargs; - $vmtab = xCAT::Table->new("vm"); + #$vmtab = xCAT::Table->new("vm"); + $vmtab = undef; unless ($offlinehyps{$hyp} or ($hyp eq '!@!XCATDUMMYHYPERVISOR!@!') or nodesockopen($hyp,22)) { $offlinehyps{$hyp}=1; }