2009-12-03 08:01:33 +00:00
|
|
|
#!/usr/bin/perl
|
|
|
|
# IBM(c) 2007 EPL license http://www.eclipse.org/legal/epl-v10.html
|
|
|
|
#(C)IBM Corp
|
|
|
|
|
2014-11-11 12:18:58 -05:00
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
=head1 restartxcatd
|
|
|
|
|
|
|
|
restartxcatd - this routine is used to restart the xcatd process group.
|
|
|
|
|
|
|
|
Linux: It will perform the xcatd fast restart. The 'xcatd fast restart'
|
|
|
|
has two advantages compares to the 'service stop and then start'.
|
|
|
|
1. The interval of xcatd out of service is very short.
|
|
|
|
2. The in processing request which initiated by old xcatd will
|
|
|
|
not be stopped by force. The old xcatd will hand over the sockets
|
|
|
|
to new xcatd, but old xcat will still be waiting for the in processing
|
|
|
|
request to finish before the exit.
|
|
|
|
|
|
|
|
It does the same thing as 'service xcatd restart' on NON-systemd OS like
|
|
|
|
rh6.x and sles11.x. But for the systemd enabled OS like rh7 and sles12,
|
|
|
|
the 'service xcatd restart' just do the 'stop and start' instead of
|
|
|
|
'xcatd fast restart'.
|
|
|
|
|
|
|
|
SO, it's recommended to use 'restartxcatd' command to restart xcatd on
|
|
|
|
systemd enable system like rh7 and sles12 instead of 'service xcatd restart' or
|
|
|
|
'systemctl restart xcatd'.
|
|
|
|
|
|
|
|
AIX: It runs 'stopsrc -s xcatd' to stop xcatd first if xcatd is active,
|
|
|
|
then runs 'startsrc -s xcatd' to start xcatd.
|
|
|
|
|
|
|
|
=cut
|
|
|
|
#-----------------------------------------------------------------------------
|
2009-12-03 08:01:33 +00:00
|
|
|
|
|
|
|
BEGIN
|
|
|
|
{
|
|
|
|
$::XCATROOT =
|
|
|
|
$ENV{'XCATROOT'} ? $ENV{'XCATROOT'}
|
|
|
|
: -d '/opt/xcat' ? '/opt/xcat'
|
|
|
|
: '/usr';
|
|
|
|
}
|
|
|
|
use lib "$::XCATROOT/lib/perl";
|
|
|
|
use Getopt::Long;
|
|
|
|
use File::Basename;
|
|
|
|
use xCAT::MsgUtils;
|
|
|
|
use xCAT::Utils;
|
|
|
|
|
2010-03-31 18:29:24 +00:00
|
|
|
my $cmd = basename($0);
|
|
|
|
# for auditing
|
|
|
|
my $current_userid = getpwuid($>);
|
|
|
|
my $rsp = {};
|
|
|
|
my $host=`hostname`;
|
|
|
|
$host=~ s/\s*//g; # remove blanks
|
2010-08-29 11:33:54 +00:00
|
|
|
# check the arguments
|
|
|
|
&parse_args($cmd);
|
|
|
|
|
2010-03-31 18:29:24 +00:00
|
|
|
$rsp->{syslogdata}->[0] ="restartxcatd invoked by $current_userid.\n";
|
|
|
|
$rsp->{userid} ->[0] = $current_userid;
|
|
|
|
$rsp->{clientname} -> [0] = $host;
|
|
|
|
$rsp->{clienttype} -> [0]= "cli";
|
|
|
|
$rsp->{command} -> [0] = $cmd;
|
|
|
|
$rsp->{status} -> [0] = "allowed";
|
|
|
|
xCAT::MsgUtils->message("SA",$rsp); # syslog and auditlog
|
2009-12-03 08:01:33 +00:00
|
|
|
|
2014-11-11 12:18:58 -05:00
|
|
|
|
|
|
|
# for Linux specific
|
|
|
|
if (xCAT::Utils->isLinux())
|
|
|
|
{
|
|
|
|
print "Restarting xCATd ";
|
|
|
|
if (-r "/etc/profile.d/xcat.sh") {
|
|
|
|
$cmd = "source /etc/profile.d/xcat.sh;";
|
|
|
|
}
|
|
|
|
|
|
|
|
$cmd .= "xcatd -p /var/run/xcatd.pid";
|
|
|
|
xCAT::Utils->runcmd("$cmd", -1);
|
|
|
|
if ($::RUNCMD_RC == 0) {
|
|
|
|
print "[ OK ]\n";
|
|
|
|
system ("logger -p local4.info -t xCAT Restart xcatd: [ OK ].");
|
|
|
|
exit 0;
|
|
|
|
} else {
|
|
|
|
print "[ FAILED ]\n";
|
|
|
|
system ("logger -p local4.info -t xCAT Restart xcatd: [ FAILED ].");
|
|
|
|
exit 1;
|
|
|
|
}
|
|
|
|
} elsif (!(xCAT::Utils->isAIX())) {
|
|
|
|
xCAT::MsgUtils->message("E", "Error: This command should only be run on Linux or AIX.");
|
|
|
|
exit 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
# Following code is for AIX only
|
|
|
|
|
|
|
|
$::RE_CHECK_NUM = 10; # the times to check the result of command, the checking interval is 1 second
|
|
|
|
|
|
|
|
my $rc;
|
|
|
|
my @output;
|
|
|
|
my $inoperative = 0;
|
|
|
|
my $check_num;
|
|
|
|
|
2009-12-03 08:01:33 +00:00
|
|
|
# Check whether the xcatd subsystem has been created
|
|
|
|
$cmd = "/usr/bin/lssrc -s xcatd | grep \"xcatd Subsystem is not on file\"";
|
|
|
|
@output = `$cmd`;
|
2009-12-04 04:32:19 +00:00
|
|
|
if (scalar(@output)) {
|
|
|
|
# create the subsystem if it does not exist
|
|
|
|
$cmd = "mkssys -p $::XCATROOT/sbin/xcatd -s xcatd -u 0 -S -n 15 -f 15 -a \"-f\"";
|
|
|
|
$rc = system($cmd);
|
|
|
|
if ($rc >> 8) {
|
2010-01-06 09:38:35 +00:00
|
|
|
xCAT::MsgUtils->message("E", "Error: Cannot create the xcatd subsystem.\n");
|
2009-12-04 04:32:19 +00:00
|
|
|
exit 1;
|
|
|
|
}
|
2009-12-03 08:01:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Check the current status of xcatd subsystem
|
|
|
|
$cmd = "lssrc -s xcatd | grep 'xcatd' | grep 'inoperative'";
|
|
|
|
@output = `$cmd`;
|
|
|
|
if (scalar(@output)) {
|
2009-12-04 04:32:19 +00:00
|
|
|
if ($::VERBOSE) {
|
|
|
|
xCAT::MsgUtils->message("I", "xcatd subsystem in inoperative status.\n");
|
|
|
|
}
|
2009-12-03 08:01:33 +00:00
|
|
|
$inoperative = 1;
|
|
|
|
}
|
|
|
|
|
2010-01-06 09:38:35 +00:00
|
|
|
if (! $inoperative) { # active
|
2009-12-03 08:01:33 +00:00
|
|
|
# Stop the xcatd subsystem
|
|
|
|
$cmd = "/usr/bin/stopsrc -s xcatd";
|
|
|
|
$rc = system($cmd);
|
|
|
|
if ($rc >> 8) {
|
2010-01-06 09:38:35 +00:00
|
|
|
xCAT::MsgUtils->message("E", "Error: Cannot run stopsrc command correctly.\n");
|
2009-12-03 08:01:33 +00:00
|
|
|
exit 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
# Wait for end of the xcatd subsystem
|
2010-03-25 10:21:08 +00:00
|
|
|
$check_num = $::RE_CHECK_NUM;
|
2009-12-03 08:01:33 +00:00
|
|
|
while ($check_num > 0) {
|
|
|
|
$cmd = "lssrc -s xcatd | grep 'xcatd' | grep 'inoperative'";
|
|
|
|
@output = `$cmd`;
|
|
|
|
if (scalar(@output) == 0) {
|
|
|
|
sleep 1;
|
|
|
|
} else {
|
|
|
|
last;
|
|
|
|
}
|
2010-01-21 03:12:10 +00:00
|
|
|
$check_num--;
|
2009-12-03 08:01:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($check_num <= 0) {
|
2010-01-06 09:38:35 +00:00
|
|
|
xCAT::MsgUtils->message("E", "Error: Cannot stop the xcatd subsystem correctly.\n");
|
2009-12-03 08:01:33 +00:00
|
|
|
exit 1;
|
|
|
|
} else {
|
2009-12-04 04:32:19 +00:00
|
|
|
if ($::VERBOSE) {
|
|
|
|
xCAT::MsgUtils->message("I", "Stopped the xcatd subsystem.\n");
|
|
|
|
}
|
2009-12-03 08:01:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-01-06 09:38:35 +00:00
|
|
|
# Kill xcatd manually if needed
|
|
|
|
$cmd = "ps -ef | grep xcatd: | grep -v grep";
|
|
|
|
@output = `$cmd`;
|
|
|
|
if (scalar(@output)) {
|
|
|
|
$cmd = "ps -ef | grep xcatd | grep 'SSL listener'";
|
|
|
|
@output = `$cmd`;
|
|
|
|
foreach my $ps (@output) {
|
|
|
|
$ps =~ s/^\s+//; # strip any leading spaces
|
|
|
|
my ($uid, $pid, $ppid, $desc) = split /\s+/, $ps;
|
|
|
|
my $cmd = "/usr/bin/kill -15 -$pid >/dev/null 2>&1";
|
|
|
|
`$cmd`;
|
|
|
|
}
|
|
|
|
# Kill the xcatd by force if it still there
|
|
|
|
$cmd = "ps -ef | grep xcatd: | grep -v grep";
|
|
|
|
@output = `$cmd`;
|
|
|
|
foreach my $ps (@output) {
|
|
|
|
$ps =~ s/^\s+//; # strip any leading spaces
|
|
|
|
my ($uid, $pid, $ppid, $desc) = split /\s+/, $ps;
|
|
|
|
my $cmd = "/usr/bin/kill -9 $pid >/dev/null 2>&1";
|
|
|
|
`$cmd`;
|
|
|
|
}
|
2010-03-25 10:21:08 +00:00
|
|
|
$check_num = $::RE_CHECK_NUM;
|
2010-01-06 09:38:35 +00:00
|
|
|
while ($check_num > 0) {
|
|
|
|
$cmd = "ps -ef | grep xcatd: | grep -v grep";
|
|
|
|
@output = `$cmd`;
|
|
|
|
if (scalar(@output)) {
|
|
|
|
sleep 1;
|
|
|
|
} else {
|
|
|
|
last;
|
|
|
|
}
|
2010-01-21 03:12:10 +00:00
|
|
|
$check_num--;
|
2010-01-06 09:38:35 +00:00
|
|
|
}
|
|
|
|
if ($check_num <= 0) {
|
|
|
|
xCAT::MsgUtils->message("E", "Error: Cannot kill the xcatd processes correctly.\n");
|
|
|
|
exit 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-12-03 08:01:33 +00:00
|
|
|
# Start the xcatd subsystem
|
|
|
|
$cmd = "/usr/bin/startsrc -s xcatd";
|
|
|
|
|
|
|
|
if ($ENV{XCATRELOAD} || $ENV{XCATROOT} || $ENV{PATH}) {
|
|
|
|
$cmd .= " -e \"";
|
|
|
|
if ($ENV{XCATRELOAD}) {
|
|
|
|
$cmd .= " XCATRELOAD=$ENV{XCATRELOAD}";
|
|
|
|
}
|
|
|
|
if ($ENV{XCATROOT}) {
|
|
|
|
$cmd .= " XCATROOT=$ENV{XCATROOT}";
|
|
|
|
}
|
|
|
|
if ($ENV{PATH}) {
|
|
|
|
$cmd .= " PATH=$ENV{PATH}";
|
|
|
|
}
|
|
|
|
$cmd .= "\"";
|
|
|
|
}
|
|
|
|
$rc = system($cmd);
|
|
|
|
if ($rc >> 8) {
|
2010-01-06 09:38:35 +00:00
|
|
|
xCAT::MsgUtils->message("E", "Error: Cannot run startsrc command correctly.\n");
|
2009-12-03 08:01:33 +00:00
|
|
|
exit 1;
|
|
|
|
}
|
2010-01-06 09:38:35 +00:00
|
|
|
# Sleep a while to make sure the startsrc has completed it's work
|
|
|
|
sleep 3;
|
2009-12-03 08:01:33 +00:00
|
|
|
|
|
|
|
# Check the status of xcatd subsystem
|
2010-03-25 10:21:08 +00:00
|
|
|
$check_num = $::RE_CHECK_NUM;
|
2009-12-03 08:01:33 +00:00
|
|
|
while ($check_num > 0) {
|
|
|
|
$cmd = "lssrc -s xcatd | grep 'xcatd' | grep 'active'";
|
|
|
|
my @output = `$cmd`;
|
|
|
|
if (scalar(@output) == 0) {
|
|
|
|
sleep 1;
|
|
|
|
} else {
|
|
|
|
last;
|
|
|
|
}
|
2010-01-21 03:12:10 +00:00
|
|
|
$check_num--;
|
2009-12-03 08:01:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($check_num <= 0) {
|
2010-01-06 09:38:35 +00:00
|
|
|
xCAT::MsgUtils->message("E", "Error: Cannot start the xcatd subsystem correctly.\n");
|
2009-12-03 08:01:33 +00:00
|
|
|
exit 1;
|
2010-08-29 11:33:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# now see if we can really talk to the database, up to a minute
|
|
|
|
$wait = 60;
|
|
|
|
while ($wait > 0) {
|
|
|
|
sleep 10;
|
|
|
|
$wait = $wait -10;
|
|
|
|
xCAT::Utils->runcmd("$::XCATROOT/sbin/tabdump site",-1);
|
|
|
|
if ($::RUNCMD_RC == 0) {
|
|
|
|
$wait=0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($::VERBOSE) {
|
2009-12-04 04:32:19 +00:00
|
|
|
xCAT::MsgUtils->message("I", "Started the xcatd subsystem.\n");
|
2009-12-03 08:01:33 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
exit 0;
|
|
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
=head3 parse_args
|
|
|
|
|
|
|
|
Parses for input
|
|
|
|
|
|
|
|
=cut
|
|
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
sub parse_args
|
|
|
|
{
|
2009-12-04 04:32:19 +00:00
|
|
|
my $usagemsg = "restartxcatd [[-h|--help] | [-v|--version] | [-r|--reload]] [-V|--verbose]\n";
|
|
|
|
|
2009-12-03 08:01:33 +00:00
|
|
|
Getopt::Long::Configure("posix_default");
|
|
|
|
Getopt::Long::Configure("no_gnu_compat");
|
|
|
|
Getopt::Long::Configure("bundling");
|
|
|
|
if (
|
|
|
|
!GetOptions(
|
|
|
|
'h|help' => \$::HELP,
|
|
|
|
'r|reload' => \$::RELOAD,
|
2009-12-04 04:32:19 +00:00
|
|
|
'v|version' => \$::VERSION,
|
|
|
|
'V|verbose' => \$::VERBOSE
|
2009-12-03 08:01:33 +00:00
|
|
|
)
|
|
|
|
)
|
|
|
|
{
|
|
|
|
xCAT::MsgUtils->message("E", $usagemsg);
|
|
|
|
exit 1;
|
|
|
|
}
|
|
|
|
if ($::HELP)
|
|
|
|
{
|
|
|
|
xCAT::MsgUtils->message("I", $usagemsg);
|
|
|
|
exit 0;
|
|
|
|
}
|
|
|
|
if ($::RELOAD)
|
|
|
|
{
|
|
|
|
$ENV{XCATRELOAD} = "yes";
|
|
|
|
}
|
|
|
|
if ($::VERSION)
|
|
|
|
{
|
|
|
|
my $version = xCAT::Utils->Version();
|
|
|
|
$version .="\n";
|
|
|
|
xCAT::MsgUtils->message("I", $version);
|
|
|
|
exit 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|