mirror of
https://github.com/xcat2/xcat-core.git
synced 2025-10-24 16:05:41 +00:00
Merge pull request #5001 from chenglch/gcons-restart
Modify startup configuration for goconserver and conserver
This commit is contained in:
@@ -559,16 +559,17 @@ sub message
|
||||
|
||||
Example:
|
||||
|
||||
$rsp->{data}->[0] = "message";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message($msg, $callback);
|
||||
=cut
|
||||
|
||||
#-----------------------------------------------------------------------------
|
||||
sub error_message
|
||||
{
|
||||
shift;
|
||||
my $rsp = shift;
|
||||
my $msg = shift;
|
||||
my $callback = shift;
|
||||
my $rsp;
|
||||
$rsp->{data}->[0] = $msg;
|
||||
if (!defined($callback)) {
|
||||
message(undef, "S", $rsp, undef);
|
||||
return;
|
||||
@@ -591,16 +592,17 @@ sub error_message
|
||||
|
||||
Example:
|
||||
|
||||
$rsp->{data}->[0] = "message";
|
||||
xCAT::MsgUtils->info_message($rsp, $callback);
|
||||
xCAT::MsgUtils->info_message($msg, $callback);
|
||||
=cut
|
||||
|
||||
#-----------------------------------------------------------------------------
|
||||
sub info_message
|
||||
{
|
||||
shift;
|
||||
my $rsp = shift;
|
||||
my $msg = shift;
|
||||
my $callback = shift;
|
||||
my $rsp;
|
||||
$rsp->{data}->[0] = $msg;
|
||||
if (!defined($callback)) {
|
||||
message(undef, "S", $rsp, undef);
|
||||
return;
|
||||
@@ -613,7 +615,38 @@ sub info_message
|
||||
message(undef, "I", $rsp, $callback);
|
||||
}
|
||||
|
||||
#-----------------------------------------------------------------------------
|
||||
|
||||
=head3 warn_message
|
||||
|
||||
A wrap function for message. If $callback is not defined, send the log to
|
||||
syslog, otherwise, send warning message to client. Print service host if runs
|
||||
on service node.
|
||||
|
||||
Example:
|
||||
|
||||
xCAT::MsgUtils->warn_message($msg, $callback);
|
||||
=cut
|
||||
|
||||
#-----------------------------------------------------------------------------
|
||||
sub warn_message
|
||||
{
|
||||
shift;
|
||||
my $msg = shift;
|
||||
my $callback = shift;
|
||||
my $rsp;
|
||||
$rsp->{data}->[0] = $msg;
|
||||
if (!defined($callback)) {
|
||||
message(undef, "S", $rsp, undef);
|
||||
return;
|
||||
}
|
||||
if ($isSN && !$host) {
|
||||
my @hostinfo = xCAT::NetworkUtils->determinehostname();
|
||||
$host = $hostinfo[-1];
|
||||
}
|
||||
$rsp->{host} = $host if $host;
|
||||
message(undef, "W", $rsp, $callback);
|
||||
}
|
||||
|
||||
#--------------------------------------------------------------------------------
|
||||
|
||||
|
@@ -104,8 +104,7 @@ sub gen_request_data {
|
||||
foreach my $node (@openbmc_nodes) {
|
||||
if (defined($openbmc_hash->{$node}->[0])) {
|
||||
if (!$openbmc_hash->{$node}->[0]->{'bmc'}) {
|
||||
$rsp->{data}->[0] = "$node: Failed to send delete request.";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("$node: Unable to get attribute bmc.", $callback);
|
||||
delete $data->{$node};
|
||||
next;
|
||||
}
|
||||
@@ -115,8 +114,7 @@ sub gen_request_data {
|
||||
} elsif ($passwd_hash and $passwd_hash->{username}) {
|
||||
$data->{$node}->{params}->{user} = $passwd_hash->{username};
|
||||
} else {
|
||||
$rsp->{data}->[0] = "$node: Unable to get attribute username.";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("$node: Unable to get attribute username.", $callback);
|
||||
delete $data->{$node};
|
||||
next;
|
||||
}
|
||||
@@ -125,8 +123,7 @@ sub gen_request_data {
|
||||
} elsif ($passwd_hash and $passwd_hash->{password}) {
|
||||
$data->{$node}->{params}->{password} = $passwd_hash->{password};
|
||||
} else {
|
||||
$rsp->{data}->[0] = "$node: Unable to get attribute password.";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("$node: Unable to get attribute password.", $callback);
|
||||
delete $data->{$node};
|
||||
next;
|
||||
}
|
||||
@@ -259,14 +256,12 @@ sub delete_nodes {
|
||||
$ret = 0;
|
||||
my $response = http_request("DELETE", $url, $data);
|
||||
if (!defined($response)) {
|
||||
$rsp->{data}->[0] = "Failed to send delete request.";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("Failed to send delete request.", $callback);
|
||||
return 1;
|
||||
} elsif ($delmode) {
|
||||
while (my ($k, $v) = each %{$response}) {
|
||||
if ($v ne "Deleted") {
|
||||
$rsp->{data}->[0] = "$k: Failed to delete entry in goconserver: $v";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("$k: Failed to delete entry in goconserver: $v", $callback);
|
||||
$ret = 1;
|
||||
} else {
|
||||
if ($callback) {
|
||||
@@ -279,8 +274,7 @@ sub delete_nodes {
|
||||
}
|
||||
if (@update_nodes) {
|
||||
if (disable_nodes_in_db(\@update_nodes)) {
|
||||
$rsp->{data}->[0] = "Failed to update consoleenabled status in db.";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("Failed to update consoleenabled status in db.", $callback);
|
||||
}
|
||||
}
|
||||
return $ret;
|
||||
@@ -297,14 +291,12 @@ sub create_nodes {
|
||||
$ret = 0;
|
||||
my $response = http_request("POST", $url, $data);
|
||||
if (!defined($response)) {
|
||||
$rsp->{data}->[0] = "Failed to send create request.";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("Failed to send create request.", $callback);
|
||||
return 1;
|
||||
} elsif ($response) {
|
||||
while (my ($k, $v) = each %{$response}) {
|
||||
if ($v ne "Created") {
|
||||
$rsp->{data}->[0] = "$k: Failed to create console entry in goconserver: $v";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("$k: Failed to create console entry in goconserver: $v", $callback);
|
||||
$ret = 1;
|
||||
} else {
|
||||
$rsp->{data}->[0] = "$k: $v";
|
||||
@@ -315,8 +307,7 @@ sub create_nodes {
|
||||
}
|
||||
if (@update_nodes) {
|
||||
if (enable_nodes_in_db(\@update_nodes)) {
|
||||
$rsp->{data}->[0] = "Failed to update consoleenabled status in db.";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("Failed to update consoleenabled status in db.", $callback);
|
||||
}
|
||||
}
|
||||
return $ret;
|
||||
@@ -328,13 +319,11 @@ sub list_nodes {
|
||||
my $rsp;
|
||||
my $response = http_request("GET", $url);
|
||||
if (!defined($response)) {
|
||||
$rsp->{data}->[0] = "Failed to send list request. Is goconserver service started?";
|
||||
xCAT::MsgUtils->error_message($rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("Failed to send list request. Is goconserver service started?", $callback);
|
||||
return 1;
|
||||
}
|
||||
if (!$response->{nodes}) {
|
||||
$rsp->{data}->[0] = "Could not find any node.";
|
||||
xCAT::MsgUtils->info_message($rsp, $callback);
|
||||
xCAT::MsgUtils->info_message("Could not find any node.", $callback);
|
||||
return 0;
|
||||
}
|
||||
$rsp->{data}->[0] = sprintf("\n".PRINT_FORMAT, "NODE", "SERVER", "STATE");
|
||||
@@ -345,8 +334,7 @@ sub list_nodes {
|
||||
}
|
||||
$node_map->{$node->{name}}->{vis} = 1;
|
||||
if (!$node->{host} || !$node->{state}) {
|
||||
$rsp->{data}->[0] = sprintf(PRINT_FORMAT, $node->{name}, "", "Unable to parse the response message");
|
||||
xCAT::MsgUtils->error_message("E", $rsp, $callback);
|
||||
xCAT::MsgUtils->error_message(sprintf(PRINT_FORMAT, $node->{name}, "", "Unable to parse the response message"), $callback);
|
||||
next;
|
||||
}
|
||||
$rsp->{data}->[0] = sprintf(PRINT_FORMAT, $node->{name}, $node->{host}, substr($node->{state}, 0, 16));
|
||||
@@ -370,8 +358,7 @@ sub cleanup_nodes {
|
||||
my $rsp;
|
||||
my $response = http_request("GET", "$api_url/nodes");
|
||||
if (!defined($response)) {
|
||||
$rsp->{data}->[0] = "Failed to send list request. Is goconserver service started?";
|
||||
xCAT::MsgUtils->error_message("E", $rsp, $callback);
|
||||
xCAT::MsgUtils->error_message("Failed to send list request. Is goconserver service started?", $callback);
|
||||
return 1;
|
||||
}
|
||||
if (!$response->{nodes}) {
|
||||
@@ -491,6 +478,70 @@ sub is_goconserver_running {
|
||||
|
||||
#-------------------------------------------------------------------------------
|
||||
|
||||
=head3 switch_goconserver
|
||||
Disable conserver and enable goconserver during startup.
|
||||
|
||||
Globals:
|
||||
none
|
||||
Example:
|
||||
xCAT::Goconserver::switch_goconserver()
|
||||
Comments:
|
||||
none
|
||||
|
||||
=cut
|
||||
|
||||
#-------------------------------------------------------------------------------
|
||||
sub switch_goconserver {
|
||||
my $callback = shift;
|
||||
# ignore SN as it is handled by AAsn
|
||||
if ((-x "/usr/bin/systemctl" || -x "-x /bin/systemctl") && !$isSN) {
|
||||
my $cmd = "systemctl disable conserver";
|
||||
xCAT::Utils->runcmd($cmd, -1);
|
||||
if ($::RUNCMD_RC != 0) {
|
||||
xCAT::MsgUtils->warn_message("Failed to execute command: $cmd.", $callback);
|
||||
}
|
||||
$cmd = "systemctl enable goconserver";
|
||||
xCAT::Utils->runcmd($cmd, -1);
|
||||
if ($::RUNCMD_RC != 0) {
|
||||
xCAT::MsgUtils->warn_message("Failed to execute command: $cmd.", $callback);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#-------------------------------------------------------------------------------
|
||||
|
||||
=head3 switch_conserver
|
||||
Disable goconserver and enable conserver during startup.
|
||||
|
||||
Globals:
|
||||
none
|
||||
Example:
|
||||
xCAT::Goconserver::switch_conserver()
|
||||
Comments:
|
||||
none
|
||||
|
||||
=cut
|
||||
|
||||
#-------------------------------------------------------------------------------
|
||||
sub switch_conserver {
|
||||
my $callback = shift;
|
||||
# ignore SN as it is handled by AAsn
|
||||
if ((-x "/usr/bin/systemctl" || -x "-x /bin/systemctl") && !$isSN) {
|
||||
my $cmd = "systemctl disable goconserver";
|
||||
xCAT::Utils->runcmd($cmd, -1);
|
||||
if ($::RUNCMD_RC != 0) {
|
||||
xCAT::MsgUtils->warn_message("Failed to execute command: $cmd.", $callback);
|
||||
}
|
||||
$cmd = "systemctl enable conserver";
|
||||
xCAT::Utils->runcmd($cmd, -1);
|
||||
if ($::RUNCMD_RC != 0) {
|
||||
xCAT::MsgUtils->warn_message("Failed to execute command: $cmd.", $callback);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#-------------------------------------------------------------------------------
|
||||
|
||||
=head3 is_conserver_running
|
||||
Check if the conserver service is running
|
||||
|
||||
|
@@ -209,6 +209,7 @@ sub process_request {
|
||||
xCAT::MsgUtils->message("E", $rsp, $cb);
|
||||
return;
|
||||
}
|
||||
xCAT::Goconserver::switch_conserver($cb);
|
||||
}
|
||||
makeconservercf($req, $cb);
|
||||
}
|
||||
|
@@ -142,16 +142,15 @@ sub process_request {
|
||||
sub start_goconserver {
|
||||
my ($rsp, $running, $ready, $ret);
|
||||
unless (-x "/usr/bin/goconserver") {
|
||||
$rsp->{data}->[0] = "goconserver is not installed.";
|
||||
xCAT::MsgUtils->error_message($rsp, $::callback);
|
||||
xCAT::MsgUtils->error_message("goconserver is not installed.", $::callback);
|
||||
return 1;
|
||||
}
|
||||
# if goconserver is installed, check the status of conserver service.
|
||||
if (xCAT::Goconserver::is_conserver_running()) {
|
||||
$rsp->{data}->[0] = "conserver is started, please stop it at first.";
|
||||
xCAT::MsgUtils->error_message($rsp, $::callback);
|
||||
xCAT::MsgUtils->error_message("conserver is started, please stop it at first.", $::callback);
|
||||
return 1;
|
||||
}
|
||||
xCAT::Goconserver::switch_goconserver($::callback);
|
||||
$running = xCAT::Goconserver::is_goconserver_running();
|
||||
$ready = xCAT::Goconserver::is_xcat_conf_ready();
|
||||
if ( $running && $ready ) {
|
||||
@@ -163,19 +162,16 @@ sub start_goconserver {
|
||||
if (!$ready) {
|
||||
$ret = xCAT::Goconserver::build_conf();
|
||||
if ($ret) {
|
||||
$rsp->{data}->[0] = "Failed to create configuration file for goconserver.";
|
||||
xCAT::MsgUtils->error_message($rsp, $::callback);
|
||||
xCAT::MsgUtils->error_message("Failed to create configuration file for goconserver.", $::callback);
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
$ret = xCAT::Goconserver::restart_service();
|
||||
if ($ret) {
|
||||
$rsp->{data}->[0] = "Failed to start goconserver service.";
|
||||
xCAT::MsgUtils->error_message($rsp, $::callback);
|
||||
xCAT::MsgUtils->error_message("Failed to start goconserver service.", $::callback);
|
||||
return 1;
|
||||
}
|
||||
$rsp->{data}->[0] = "Starting goconserver service ...";
|
||||
xCAT::MsgUtils->info_message($rsp, $::callback);
|
||||
xCAT::MsgUtils->info_message("Starting goconserver service ...", $::callback);
|
||||
sleep(3);
|
||||
return 0;
|
||||
}
|
||||
@@ -203,16 +199,14 @@ sub makegocons {
|
||||
}
|
||||
if ($cleanupmode) {
|
||||
if (exists($req->{_allnodes}) && $req->{_allnodes}->[0] != 1) {
|
||||
$rsp->{data}->[0] = "Failed to start goconserver service.";
|
||||
xCAT::MsgUtils->error_message($rsp, $::callback);
|
||||
xCAT::MsgUtils->error_message("Can not specify noderange together with -C|--cleanup.", $::callback);
|
||||
return 1;
|
||||
}
|
||||
return xCAT::Goconserver::cleanup_nodes($::callback);
|
||||
}
|
||||
my %cons_map = xCAT::Goconserver::get_cons_map($req);
|
||||
if (! %cons_map) {
|
||||
$rsp->{data}->[0] = "Could not get any console request entry.";
|
||||
xCAT::MsgUtils->error_message($rsp, $::callback);
|
||||
xCAT::MsgUtils->error_message("Could not get any console request entry.", $::callback);
|
||||
return 1;
|
||||
}
|
||||
my $api_url = "https://$host:". xCAT::Goconserver::get_api_port();
|
||||
@@ -233,15 +227,13 @@ sub makegocons {
|
||||
}
|
||||
elsif (lc($site_entry) ne "no") {
|
||||
# consoleondemand attribute is set, but it is not "yes" or "no"
|
||||
$rsp->{data}->[0] = "Unexpected value $site_entry for consoleondemand attribute in site table.";
|
||||
xCAT::MsgUtils->error_message($rsp, $::callback);
|
||||
xCAT::MsgUtils->error_message("Unexpected value $site_entry for consoleondemand attribute in site table.", $::callback);
|
||||
}
|
||||
}
|
||||
my (@nodes);
|
||||
my $data = xCAT::Goconserver::gen_request_data(\%cons_map, $siteondemand, $::callback);
|
||||
if (! $data) {
|
||||
$rsp->{data}->[0] = "Could not generate the request data.";
|
||||
xCAT::MsgUtils->error_message($rsp, $::callback);
|
||||
xCAT::MsgUtils->error_message("Could not generate the request data.", $::callback);
|
||||
return 1;
|
||||
}
|
||||
$ret = xCAT::Goconserver::delete_nodes($api_url, $data, $delmode, $::callback);
|
||||
@@ -250,8 +242,7 @@ sub makegocons {
|
||||
}
|
||||
$ret = xCAT::Goconserver::create_nodes($api_url, $data, $::callback);
|
||||
if ($ret != 0) {
|
||||
$rsp->{data}->[0] = "Failed to create console entry in goconserver.";
|
||||
xCAT::MsgUtils->error_message($rsp, $::callback);
|
||||
xCAT::MsgUtils->error_message("Failed to create console entry in goconserver.", $::callback);
|
||||
return $ret;
|
||||
}
|
||||
return 0;
|
||||
|
Reference in New Issue
Block a user