add support for dump re-target

git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@12036 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd
This commit is contained in:
nott 2012-03-28 13:39:48 +00:00
parent 8fe63331bd
commit cb4a9f01cb

View File

@ -167,6 +167,10 @@ sub process_request
&usage($callback);
return 1;
}
my $rsp;
push @{$rsp->{data}}, "Moving nodes to their backup service nodes.\n";
xCAT::MsgUtils->message("I", $rsp, $callback);
#
# get the list of nodes
@ -555,7 +559,14 @@ sub process_request
my %SLmodhash;
my %LTmodhash;
if ($::isaix)
# check the sharedinstall attr
my $sharedinstall=xCAT::Utils->get_site_attribute('sharedinstall');
chomp $sharedinstall;
if (!$sharedinstall) {
$sharedinstall="no";
}
if ( ($::isaix) && ($sharedinstall eq "no") )
{
#
@ -746,17 +757,15 @@ sub process_request
} # end sync statelite and litetree entries
if ($::VERBOSE)
{
my $rsp;
push @{$rsp->{data}}, "Setting new values in the xCAT database.\n";
xCAT::MsgUtils->message("I", $rsp, $callback);
}
my $rsp;
push @{$rsp->{data}}, "Setting new values in the xCAT database.\n";
xCAT::MsgUtils->message("I", $rsp, $callback);
#
# make updates to statelite table
#
if ($::isaix)
if ( ($::isaix) && ($sharedinstall eq "no") )
{
my $statetab = xCAT::Table->new('statelite', -create => 1);
@ -833,7 +842,21 @@ sub process_request
$sub_req, 0, 1
);
$callback->({data => $ret});
}
}
#
# - retarget the iscsi dump device to the new server for the nodes
#
if ((!$::IGNORE) && ($::isaix)) {
if (&dump_retarget($callback, \@nodes, $sub_req) != 0)
{
my $rsp;
push @{$rsp->{data}}, "One or more errors occured while attemping to re-target the dump device on cluster nodes.\n";
xCAT::MsgUtils->message("E", $rsp, $callback);
$error++;
}
}
#
# Run niminit on AIX diskful nodes
@ -852,6 +875,13 @@ sub process_request
if (($nimtype{$node}) && ($nimtype{$node} eq 'standalone'))
{
if ($::VERBOSE)
{
my $rsp;
push @{$rsp->{data}},"Running niminit on $node.\n";
xCAT::MsgUtils->message("I", $rsp, $callback);
}
my $nimcmd =
qq~/usr/sbin/niminit -a name=$node -a master=$newsn{$node} >/dev/null 2>&1~;
@ -948,12 +978,18 @@ sub process_request
# update the /etc/xcatinfo files on the nodes
# switch to the new server name
#
if (0) { # save this for later - not needed yet
if (!$::IGNORE)
{
if ($::isaix)
{
if ($::VERBOSE)
{
my $rsp;
push @{$rsp->{data}}, "Updating the /etc/xcatinfo files.\n";
xCAT::MsgUtils->message("I", $rsp, $callback);
}
foreach my $node (@nodes)
{
@ -983,7 +1019,6 @@ if (0) { # save this for later - not needed yet
}
} # end if isaix
} # end of not ignore
} # end of not needed
if (!$::IGNORE)
{
@ -1303,8 +1338,7 @@ if (0) { # save this for later - not needed yet
sub getSNinterfaces
{
#my ($class, $list, $callback, $subreq) = @_;
my ($list, $callback, $subreq) = @_;
my ($list, $callback, $sub_req) = @_;
my @snlist = @$list;
@ -1329,7 +1363,7 @@ sub getSNinterfaces
my $SNIP;
my $result =
xCAT::InstUtils->xcmd($callback, $subreq, "xdsh", $sn, $ifcmd, 0);
xCAT::InstUtils->xcmd($callback, $sub_req, "xdsh", $sn, $ifcmd, 0);
if ($::RUNCMD_RC != 0)
{
my $rsp = {};
@ -1418,3 +1452,315 @@ sub usage
return 0;
}
#----------------------------------------------------------------------------
=head3 dump_retarget
Switches the iscsi dump target of nodes to a backup service node.
Arguments:
Returns:
0 - OK
1 - error
Usage: $ret = &dump_retarget($callback, \@nodelist, $sub_req);
=cut
#-----------------------------------------------------------------------------
sub dump_retarget
{
my $callback = shift;
my $nodelist = shift;
my $sub_req = shift;
my @nodes = @$nodelist;
my $error;
my $rsp;
push @{$rsp->{data}}, "Re-targetting dump devices for:\n\'@nodes\'\n";
xCAT::MsgUtils->message("I", $rsp, $callback);
# get provmethod and xcatmaster for each node
my $nrtab = xCAT::Table->new('noderes');
my $nttab = xCAT::Table->new('nodetype');
my $nrhash;
my $nthash;
if ($nrtab)
{
$nrhash = $nrtab->getNodesAttribs(\@nodes, ['xcatmaster', 'servicenode']);
}
else
{
my $rsp = {};
$rsp->{data}->[0] = "Can not open noderes table.\n";
xCAT::MsgUtils->message("E", $rsp, $callback, 1);
}
if ($nttab)
{
$nthash = $nttab->getNodesAttribs(\@nodes, ['provmethod']);
}
else
{
my $rsp = {};
$rsp->{data}->[0] = "Can not open nodetype table.\n";
xCAT::MsgUtils->message("E", $rsp, $callback, 1);
}
# get the network info for each node
# $nethash{nodename}{networks attr name} = value
my %nethash = xCAT::DBobjUtils->getNetwkInfo(\@nodes);
# get a list of nodes for each SNs and osimage combo
# - also a list of osimages.
my %SNosinodes;
my @image_names;
my %SNname;
foreach my $node (@nodes)
{
my $xmast = $nrhash->{$node}->[0]->{'xcatmaster'};
my ($snode, $junk) = (split /,/, $nrhash->{$node}->[0]->{'servicenode'});
my $osimage = $nthash->{$node}->[0]->{'provmethod'};
push(@{$SNosinodes{$xmast}{$osimage}}, $node);
if (!grep(/^$osimage$/, @image_names) ) {
push(@image_names, $osimage);
}
$SNname{$xmast}=$snode;
}
#
# get the image defs from the DB
#
my %imghash;
my %objtype;
# for each image
foreach my $m (@image_names)
{
$objtype{$m} = 'osimage';
}
my %imghash = xCAT::DBobjUtils->getobjdefs(\%objtype, $callback);
if (!(%imghash))
{
my $rsp;
push @{$rsp->{data}}, "Could not get xCAT osimage definitions.\n";
xCAT::MsgUtils->message("E", $rsp, $callback);
}
# set the default port - todo - user could have set differently???
my $dump_port=32600;
# for each SN
foreach my $sn (keys %SNosinodes)
{
# get ip addr of SN as known by the node
# - sn is "xcatmaster"
chomp $sn;
my $SNip = xCAT::NetworkUtils->getipaddr($sn);
# this is "servicenode" value - get first in list
my ($xcatSNname, $junk) = (split /,/, $SNname{$sn});
# for each osimage needed for this SN
foreach my $osi (keys %{$SNosinodes{$sn}})
{
# get dump target and lun from nim dump res def
my @attrs = ("dump_target", "dump_lunid");
my $na = &getnimattr($imghash{$osi}{'dump'}, \@attrs, $callback, $xcatSNname, $sub_req);
my %nimattrs = %{$na};
my $dump_target = $nimattrs{dump_target};
my $dump_lunid = $nimattrs{dump_lunid};
# get configdump value from xCAT osimage def
my $configdump;
if ($imghash{$osi}{'configdump'}) {
$configdump = $imghash{$osi}{'configdump'};
} else {
$configdump = "selective";
}
if ($::VERBOSE) {
# print values ??
# or cmd??
}
if (!$dump_target || !$dump_port || !$SNip || !$dump_lunid) {
my $rsp;
push @{$rsp->{data}}, "Could not re-target the dump device for the following nodes. \n@{$SNosinodes{$sn}{$osi}}\n";
xCAT::MsgUtils->message("E", $rsp, $callback);
$error++;
next;
}
my @nodelist = @{$SNosinodes{$sn}{$osi}};
foreach my $nd (@nodelist) {
chomp $nd;
my $Nodeip = xCAT::NetworkUtils->getipaddr($nd);
# need node gateway
my $gateway = $nethash{$nd}{'gateway'};
# This should configure the iscsi disc on the client
my $tcmd = qq~/usr/lpp/bos.sysmgt/nim/methods/c_disc_target -a operation=discover -a target="$dump_target" -a dump_port="$dump_port" -a ipaddr="$SNip" -a lun_id="$dump_lunid"~;
my $hd = xCAT::InstUtils->xcmd($callback, $sub_req, "xdsh", $nd, $tcmd, 0);
if ($::RUNCMD_RC != 0)
{
my $rsp;
push @{$rsp->{data}}, "Could not run \'$tcmd\' on node $nd.\
n";
xCAT::MsgUtils->message("E", $rsp, $callback);
$error++;
next;
}
chomp $hd;
my $hdisk = $hd;
if ($hd =~ /:/) {
my $node;
($node, $hdisk) = split(': ', $hd);
}
chomp $hdisk;
$hdisk =~ s/\s*//g;
# define the disk on the client
my $mkcmd = qq~/usr/sbin/mkdev -l $hdisk~;
my $output = xCAT::InstUtils->xcmd($callback, $sub_req, "xdsh", $nd, $mkcmd, 0);
if ($::RUNCMD_RC != 0)
{
my $rsp;
push @{$rsp->{data}}, "Could not run \'$mkcmd\' on node $nd.\n";
xCAT::MsgUtils->message("E", $rsp, $callback);
$error++;
next;
}
# configure the dump device, select either selective or full
# for the configdump attribute.
my $ccmd = qq~/usr/lpp/bos.sysmgt/nim/methods/c_config_dump -a configdump=$configdump -a target=$dump_target -a dump_port=$dump_port -a ipaddr=$SNip -a lun_id=$dump_lunid~;
$output = xCAT::InstUtils->xcmd($callback, $sub_req, "xdsh",
$nd, $ccmd, 0);
if ($::RUNCMD_RC != 0)
{
my $rsp;
push @{$rsp->{data}}, "Could not run \'$ccmd\' on node $nd.\n";
xCAT::MsgUtils->message("E", $rsp, $callback);
$error++;
next;
}
# set the dump disk:
my $syscmd = qq~/usr/bin/sysdumpdev -p /dev/$hdisk~;
$output = xCAT::InstUtils->xcmd($callback, $sub_req, "xdsh", $nd, $syscmd, 0);
if ($::RUNCMD_RC != 0)
{
my $rsp;
push @{$rsp->{data}}, "Could not run \'$syscmd\' on node $nd.\n";
xCAT::MsgUtils->message("E", $rsp, $callback);
$error++;
next;
}
# point to the new server
my $blcmd = qq~/usr/bin/bootlist -m normal ent0 gateway=$gateway bserver=$SNip client=$Nodeip ~;
$output = xCAT::InstUtils->xcmd($callback, $sub_req, "xdsh", $nd, $blcmd, 0);
if ($::RUNCMD_RC != 0)
{
my $rsp;
push @{$rsp->{data}}, "Could not run \'$blcmd\' on node $nd.\n";
xCAT::MsgUtils->message("E", $rsp, $callback);
$error++;
next;
}
my $rsp;
push @{$rsp->{data}}, "Set the primary dump device for node \'$nd\' to \'/dev/$hdisk\' and changed the dump target to \'$sn\'.\n";
xCAT::MsgUtils->message("I", $rsp, $callback);
}
}
}
if ($error) {
return 1;
}
return 0;
}
#----------------------------------------------------------------------------
=head3 getnimattr
Get the specified nim attrs form the named server
Returns:
undef - error
hash ref -
=cut
#-----------------------------------------------------------------------------
sub getnimattr
{
my $resname = shift;
my $attr = shift;
my $callback = shift;
my $target = shift;
my $sub_req = shift;
my @attrs = @$attr;
my %attrval;
if (!$target)
{
$target = xCAT::InstUtils->getnimprime();
}
chomp $target;
my $ncmd = "/usr/sbin/lsnim ";
foreach my $a (@attrs)
{
$ncmd .= "-a $a ";
}
$ncmd .= "$resname 2>/dev/null";
my $attrlist = xCAT::InstUtils->xcmd($callback, $sub_req, "xdsh", $target, $ncmd, 0);
if ($::RUNCMD_RC != 0)
{
if ($::VERBOSE) {
my $rsp;
push @{$rsp->{data}}, "Could not run lsnim command: \'$ncmd\'.\n";
xCAT::MsgUtils->message("E", $rsp, $callback);
}
return undef;
}
foreach my $line (split(/\n/, $attrlist) ){
# look for attr name
foreach my $a (@attrs) {
chomp $a;
if ($line =~ /$a/) {
my ($stuff, $value) = split('=', $line);
chomp $value;
my ($val, $rest) = split(' ', $value);
# add to hash
$attrval{$a} = $val;
}
}
}
return \%attrval;
}