2018-08-13 22:25:48 +00:00
|
|
|
#!/usr/bin/perl
|
|
|
|
#
|
|
|
|
# This updates the host system.
|
|
|
|
# NOTE: This doesn't update the Anvil! software stack yet, just the OS.
|
|
|
|
#
|
|
|
|
# - On Striker; This will take the system offline and then run 'dnf -y update'.
|
|
|
|
# - On Nodes; This will do nothing until all servers are off the node. Then the node will be withdrawn,
|
|
|
|
# updated and then rejoin the cluster.
|
|
|
|
# - On DR; This will do nothing until no servers are running, then it will update the system.
|
|
|
|
#
|
2018-08-14 07:45:36 +00:00
|
|
|
# In all cases, the system will be rebooted if the kernel is updated.
|
2018-08-13 22:25:48 +00:00
|
|
|
#
|
2018-08-14 07:45:36 +00:00
|
|
|
# Exit codes;
|
|
|
|
# 0 = Normal exit.
|
|
|
|
# 1 = No database connections available.
|
|
|
|
# 2 = The job UUID was passed, but it wasn't valid.
|
|
|
|
# 3 = It looks like the update failed, reset progress to '0'.
|
2023-07-15 20:19:21 +00:00
|
|
|
# 4 = Failed to withdraw the node from the cluster.
|
2018-08-27 06:51:53 +00:00
|
|
|
#
|
2018-09-07 05:29:43 +00:00
|
|
|
# TODO:
|
2023-06-20 01:44:45 +00:00
|
|
|
# - Rebuild this to be 'striker-update-system' and have it update local strikers and all nodes.
|
2018-09-07 05:29:43 +00:00
|
|
|
#
|
2018-08-14 07:45:36 +00:00
|
|
|
|
2018-08-13 22:25:48 +00:00
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
use Anvil::Tools;
|
|
|
|
|
|
|
|
# Disable buffering
|
|
|
|
$| = 1;
|
|
|
|
|
|
|
|
my $THIS_FILE = ($0 =~ /^.*\/(.*)$/)[0];
|
|
|
|
my $running_directory = ($0 =~ /^(.*?)\/$THIS_FILE$/)[0];
|
|
|
|
if (($running_directory =~ /^\./) && ($ENV{PWD}))
|
|
|
|
{
|
|
|
|
$running_directory =~ s/^\./$ENV{PWD}/;
|
|
|
|
}
|
|
|
|
|
2019-01-18 08:19:36 +00:00
|
|
|
my $anvil = Anvil::Tools->new();
|
2018-08-13 22:25:48 +00:00
|
|
|
|
2023-07-15 02:29:07 +00:00
|
|
|
# Read switches (target ([user@]host[:port]) and the file with the target's password.
|
|
|
|
$anvil->Get->switches({list => [
|
|
|
|
"clear-cache",
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
"no-db",
|
2023-07-17 00:45:47 +00:00
|
|
|
"no-reboot",
|
|
|
|
"reboot"], man => $THIS_FILE});
|
2023-07-15 02:29:07 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => $anvil->data->{switches}});
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 2, key => "log_0115", variables => { program => $THIS_FILE }});
|
2018-08-14 07:45:36 +00:00
|
|
|
|
|
|
|
# Connect to DBs.
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
if ($anvil->data->{switches}{'no-db'})
|
2018-08-13 22:25:48 +00:00
|
|
|
{
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, 'print' => 1, level => 0, secure => 0, key => "log_0743"});
|
|
|
|
|
|
|
|
# If there was a job-uuid, clear it.
|
|
|
|
$anvil->data->{sys}{database}{connections} = 0;
|
|
|
|
$anvil->data->{switches}{'job-uuid'} = "";
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
'sys::database::connections' => $anvil->data->{sys}{database}{connections},
|
|
|
|
'switches::job-uuid' => $anvil->data->{switches}{'job-uuid'},
|
|
|
|
}});
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$anvil->Database->connect;
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 3, secure => 0, key => "log_0132"});
|
|
|
|
if (not $anvil->data->{sys}{database}{connections})
|
|
|
|
{
|
|
|
|
# No databases, exit.
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, 'print' => 1, level => 0, secure => 0, key => "error_0003"});
|
|
|
|
$anvil->nice_exit({exit_code => 1});
|
|
|
|
}
|
2018-08-13 22:25:48 +00:00
|
|
|
}
|
|
|
|
|
2023-07-25 23:13:41 +00:00
|
|
|
$anvil->data->{jobs}{job_uuid} = "";
|
2018-08-14 07:45:36 +00:00
|
|
|
if ($anvil->data->{switches}{'job-uuid'})
|
|
|
|
{
|
2023-07-23 00:03:39 +00:00
|
|
|
# See if another instance is running. If so, sleep for 10 seconds and then exit. The other instance
|
|
|
|
# could be the '--no-db' run we're about to clobber.
|
|
|
|
my $pids = $anvil->System->pids({
|
|
|
|
ignore_me => 1,
|
|
|
|
program_name => $THIS_FILE,
|
|
|
|
});
|
|
|
|
my $other_instances = @{$pids};
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { other_instances => $other_instances }});
|
|
|
|
|
|
|
|
if ($other_instances)
|
|
|
|
{
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, 'print' => 1, level => 1, key => "message_0233", variables => { program => $THIS_FILE }});
|
|
|
|
sleep 10;
|
|
|
|
$anvil->nice_exit({exit_code => 0});
|
|
|
|
}
|
|
|
|
|
2019-02-14 09:25:52 +00:00
|
|
|
# Load the job details. If anything is returned, there was a problem.
|
|
|
|
my $return = $anvil->Job->get_job_details({job_uuid => $anvil->data->{switches}{'job-uuid'}});
|
|
|
|
if ($return)
|
2018-08-14 07:45:36 +00:00
|
|
|
{
|
|
|
|
# It's not a UUID.
|
2019-02-14 09:25:52 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 1, list => { 'return' => $return }});
|
2020-06-24 04:39:56 +00:00
|
|
|
$anvil->nice_exit({exit_code => 2});
|
2018-08-14 07:45:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
# Clear any old runs.
|
2018-08-27 06:51:53 +00:00
|
|
|
update_progress($anvil, 0, "clear");
|
|
|
|
|
2018-09-01 17:08:24 +00:00
|
|
|
# We'll keep a count of lines and packages to show the user.
|
|
|
|
$anvil->data->{counts}{downloaded} = 0;
|
|
|
|
$anvil->data->{counts}{installed} = 0;
|
|
|
|
$anvil->data->{counts}{verified} = 0;
|
|
|
|
$anvil->data->{counts}{lines} = 0;
|
|
|
|
|
2018-08-14 07:45:36 +00:00
|
|
|
# Mark that we're starting
|
2018-09-03 06:35:25 +00:00
|
|
|
update_progress($anvil, 1, "message_0058,!!downloaded!0!!,!!installed!0!!,!!verified!0!!,!!lines!0!!");
|
|
|
|
update_progress($anvil, 2, "message_0033");
|
2018-08-24 04:52:56 +00:00
|
|
|
|
2018-08-30 06:24:25 +00:00
|
|
|
# Make sure maintenance mode is enabled.
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
$anvil->System->maintenance_mode({set => 1}) if $anvil->data->{sys}{database}{connections};
|
2018-08-30 06:24:25 +00:00
|
|
|
|
2018-08-29 23:52:05 +00:00
|
|
|
# Run the update
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
run_os_update($anvil, 3);
|
2018-08-14 07:45:36 +00:00
|
|
|
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
# If we had no database, try to reconnect now tha
|
|
|
|
if (not $anvil->data->{sys}{database}{connections})
|
|
|
|
{
|
|
|
|
# Start the anvil-daemon, the caller likely called without a DB because we're being updated by
|
|
|
|
# striker-update-cluster, and so there will be a job waiting for us.
|
|
|
|
$anvil->System->enable_daemon({now => 1, daemon => "anvil-daemon"});
|
2023-07-23 02:21:48 +00:00
|
|
|
$anvil->System->enable_daemon({now => 1, daemon => "scancore"});
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
|
|
|
|
$anvil->Database->connect;
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 2, secure => 0, key => "log_0132"});
|
|
|
|
|
|
|
|
if ($anvil->data->{sys}{database}{connections})
|
|
|
|
{
|
|
|
|
# If there's a job for us waiting, mark it as almost done.
|
|
|
|
my $query = "
|
|
|
|
SELECT
|
|
|
|
job_uuid
|
|
|
|
FROM
|
|
|
|
jobs
|
|
|
|
WHERE
|
|
|
|
job_command LIKE '%".$THIS_FILE."%'
|
|
|
|
AND
|
|
|
|
job_host_uuid = ".$anvil->Database->quote($anvil->Get->host_uuid)."
|
|
|
|
AND
|
|
|
|
job_progress = 0
|
|
|
|
;";
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { query => $query }});
|
|
|
|
|
|
|
|
my $job_uuid = $anvil->Database->query({query => $query, source => $THIS_FILE, line => __LINE__})->[0]->[0];
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { job_uuid => $job_uuid }});
|
|
|
|
|
|
|
|
if ($job_uuid)
|
|
|
|
{
|
2023-07-25 16:43:28 +00:00
|
|
|
$anvil->data->{jobs}{job_uuid} = $job_uuid;
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
$anvil->data->{switches}{'job-uuid'} = $job_uuid;
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
2023-07-25 16:43:28 +00:00
|
|
|
'jobs::job_uuid' => $anvil->data->{jobs}{job_uuid},
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
'switches::job-uuid' => $anvil->data->{switches}{'job-uuid'},
|
|
|
|
}});
|
|
|
|
|
|
|
|
update_progress($anvil, 0, "clear");
|
|
|
|
update_progress($anvil, 90, "message_0324");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-14 07:45:36 +00:00
|
|
|
# We're done updating
|
2021-06-09 03:56:48 +00:00
|
|
|
my $reboot_needed = $anvil->System->reboot_needed({debug => 2});
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { reboot_needed => $reboot_needed }});
|
2018-08-22 06:16:56 +00:00
|
|
|
if ($reboot_needed)
|
|
|
|
{
|
2023-07-15 02:29:07 +00:00
|
|
|
if (not $anvil->data->{switches}{'no-reboot'})
|
|
|
|
{
|
|
|
|
# Clear maintenance mode.
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
$anvil->System->maintenance_mode({set => 0}) if $anvil->data->{sys}{database}{connections};
|
2023-07-15 02:29:07 +00:00
|
|
|
|
|
|
|
# Record that we're rebooting so that 'striker-update-cluster' knows to wait for a reboot.
|
2023-07-15 02:52:51 +00:00
|
|
|
if ($anvil->data->{switches}{'job-uuid'})
|
|
|
|
{
|
|
|
|
my $query = "
|
|
|
|
UPDATE
|
|
|
|
jobs
|
|
|
|
SET
|
|
|
|
job_data = 'rebooted',
|
|
|
|
modified_date = ".$anvil->Database->quote($anvil->Database->refresh_timestamp)."
|
|
|
|
WHERE
|
|
|
|
job_uuid = ".$anvil->Database->quote($anvil->data->{switches}{'job-uuid'})."
|
|
|
|
;";
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { query => $query }});
|
|
|
|
$anvil->Database->write({query => $query, source => $THIS_FILE, line => __LINE__});
|
|
|
|
}
|
2023-07-15 02:29:07 +00:00
|
|
|
|
2023-07-16 02:23:30 +00:00
|
|
|
# Register a job to reboot.
|
|
|
|
update_progress($anvil, 98, "message_0318");
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
|
2023-07-24 01:40:49 +00:00
|
|
|
# Record that we're going to reboot now.
|
|
|
|
update_progress($anvil, 100, "message_0317");
|
|
|
|
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
if ($anvil->data->{sys}{database}{connections})
|
|
|
|
{
|
|
|
|
my ($job_uuid) = $anvil->Database->insert_or_update_jobs({
|
|
|
|
file => $THIS_FILE,
|
|
|
|
line => __LINE__,
|
|
|
|
job_command => $anvil->data->{path}{exe}{'anvil-manage-power'}." --reboot -y".$anvil->Log->switches,
|
|
|
|
job_data => "",
|
|
|
|
job_name => "reboot::system",
|
|
|
|
job_title => "job_0009",
|
|
|
|
job_description => "job_0006",
|
|
|
|
job_progress => 0,
|
2023-07-24 01:40:49 +00:00
|
|
|
job_status => "anvil_startup",
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
});
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { job_uuid => $job_uuid }});
|
2023-07-24 01:40:49 +00:00
|
|
|
|
|
|
|
# If we got a job UUID, unlink the cache file.
|
|
|
|
if (-e $anvil->data->{path}{data}{reboot_cache})
|
|
|
|
{
|
|
|
|
unlink $anvil->data->{path}{data}{reboot_cache};
|
|
|
|
}
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
}
|
2023-07-15 02:29:07 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
# Record that a reboot is needed.
|
|
|
|
update_progress($anvil, 100, "message_0039");
|
|
|
|
}
|
2018-08-22 06:16:56 +00:00
|
|
|
}
|
|
|
|
else
|
2018-08-14 07:45:36 +00:00
|
|
|
{
|
2018-08-22 06:16:56 +00:00
|
|
|
update_progress($anvil, 100, "message_0040");
|
2018-08-14 07:45:36 +00:00
|
|
|
}
|
2018-08-13 22:25:48 +00:00
|
|
|
|
2018-08-30 06:24:25 +00:00
|
|
|
# Clear maintenance mode.
|
Major thing in this commit is reworking striker-update-cluster to work without expecting anvil-daemon to be running on target machines. Similarly, they had to be able to work when the Striker DBs were not available. This is to account for cases where the Striker dashboards have updated, and the schema has changed, preventing the not-yet-updated DR hosts and subnodes from being able to use the DB. To do this, anvil-safe-stop, anvil-update-system, and anvil-shutdown-server had to be updated to use the new --no-db switch, which tells then to run without the database being available.
* Updated Server->shutdown_virsh() to work without a database connection.
* Updated System->reboot_needed() to store/read from a cache file when the database is not available.
* Updated anvil-safe-start to remove the old --enable/disable/status switches, now that we use anvil-safe-start.service systemd unit.
* Reworked anvil-safe-stop to work without a database connection, and to work on DR hosts.
* Updated anvil-special-operations to add new tasks, but it's likely these new tasks aren't needed and will be removed very shortly.
* Added/updated multiple man pages.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-22 22:09:01 +00:00
|
|
|
$anvil->System->maintenance_mode({set => 0}) if $anvil->data->{sys}{database}{connections};
|
2018-08-30 06:24:25 +00:00
|
|
|
|
2018-08-13 22:25:48 +00:00
|
|
|
$anvil->nice_exit({exit_code => 0});
|
|
|
|
|
2018-08-22 06:16:56 +00:00
|
|
|
|
2018-08-13 22:25:48 +00:00
|
|
|
#############################################################################################################
|
|
|
|
# Functions #
|
|
|
|
#############################################################################################################
|
|
|
|
|
|
|
|
# This updates the progress if we were called with a job UUID.
|
|
|
|
sub update_progress
|
|
|
|
{
|
2018-08-22 06:16:56 +00:00
|
|
|
my ($anvil, $progress, $message) = @_;
|
2018-08-13 22:25:48 +00:00
|
|
|
|
2018-08-14 07:45:36 +00:00
|
|
|
# Log the progress percentage.
|
2023-07-25 16:43:28 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
2018-08-27 06:51:53 +00:00
|
|
|
progress => $progress,
|
|
|
|
message => $message,
|
|
|
|
"jobs::job_uuid" => $anvil->data->{jobs}{job_uuid},
|
|
|
|
}});
|
2018-08-14 07:45:36 +00:00
|
|
|
|
2023-07-24 01:40:49 +00:00
|
|
|
if ($progress > 100)
|
|
|
|
{
|
|
|
|
$progress = 100;
|
2023-07-25 16:43:28 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { progress => $progress }});
|
2023-07-24 01:40:49 +00:00
|
|
|
}
|
|
|
|
|
2018-08-13 22:25:48 +00:00
|
|
|
if ($anvil->data->{jobs}{job_uuid})
|
|
|
|
{
|
2018-09-04 22:57:09 +00:00
|
|
|
$anvil->Job->update_progress({
|
2023-07-25 16:43:28 +00:00
|
|
|
debug => 2,
|
2023-07-17 00:45:47 +00:00
|
|
|
'print' => 1,
|
2018-09-04 22:57:09 +00:00
|
|
|
progress => $progress,
|
|
|
|
message => $message,
|
2018-09-06 05:37:08 +00:00
|
|
|
job_uuid => $anvil->data->{jobs}{job_uuid},
|
|
|
|
});
|
2018-08-13 22:25:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
# This updates the OS.
|
|
|
|
sub run_os_update
|
|
|
|
{
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
my ($anvil, $progress) = @_;
|
2023-07-24 01:40:49 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { progress => $progress }});
|
2018-08-13 22:25:48 +00:00
|
|
|
|
2018-12-11 18:13:35 +00:00
|
|
|
# This needs to be set to avoid warnings when called without a job-uuid.
|
|
|
|
$anvil->data->{sys}{last_update} = 0;
|
|
|
|
|
2023-07-15 02:29:07 +00:00
|
|
|
# Make sure that, if we're a node, we're out of the cluster.
|
|
|
|
my $host_type = $anvil->Get->host_type();
|
2023-07-24 01:40:49 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { host_type => $host_type }});
|
2023-07-15 02:29:07 +00:00
|
|
|
if ($host_type eq "node")
|
|
|
|
{
|
|
|
|
# Call anvil-safe-stop
|
2023-07-17 00:45:47 +00:00
|
|
|
update_progress($anvil, $progress++, "message_0314");
|
2023-07-15 02:29:07 +00:00
|
|
|
|
2023-07-24 01:40:49 +00:00
|
|
|
my $problem = $anvil->Cluster->parse_cib();
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { problem => $problem }});
|
2023-07-15 02:29:07 +00:00
|
|
|
if (not $problem)
|
|
|
|
{
|
|
|
|
# Call anvil-safe-stop
|
2023-07-17 00:45:47 +00:00
|
|
|
update_progress($anvil, $progress++, "message_0315");
|
2023-07-15 02:29:07 +00:00
|
|
|
|
|
|
|
my $shell_call = $anvil->data->{path}{exe}{'anvil-safe-stop'};
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { shell_call => $shell_call }});
|
|
|
|
|
|
|
|
my ($output, $return_code) = $anvil->System->call({shell_call => $shell_call});
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
output => $output,
|
|
|
|
return_code => $return_code,
|
|
|
|
}});
|
2023-07-15 20:19:21 +00:00
|
|
|
|
|
|
|
if ($return_code)
|
|
|
|
{
|
|
|
|
# Something went wrong, abort.
|
|
|
|
update_progress($anvil, 100, "error_0420,!!return_code!".$return_code."!!,!!output!".$output."!!");
|
|
|
|
|
|
|
|
# Set the job_data to 'failed' so that striker-update-cluster' knows to abort.
|
|
|
|
if ($anvil->data->{switches}{'job-uuid'})
|
|
|
|
{
|
|
|
|
my $query = "
|
|
|
|
UPDATE
|
|
|
|
jobs
|
|
|
|
SET
|
|
|
|
job_data = 'failed',
|
|
|
|
modified_date = ".$anvil->Database->quote($anvil->Database->refresh_timestamp)."
|
|
|
|
WHERE
|
|
|
|
job_uuid = ".$anvil->Database->quote($anvil->data->{switches}{'job-uuid'})."
|
|
|
|
;";
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { query => $query }});
|
|
|
|
$anvil->Database->write({query => $query, source => $THIS_FILE, line => __LINE__});
|
|
|
|
}
|
|
|
|
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, secure => 0, key => "error_0035", variables => { output => $output } });
|
|
|
|
$anvil->nice_exit({exit_code => 4});
|
|
|
|
}
|
2023-07-15 02:29:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Should we clear the cache?
|
|
|
|
if ($anvil->data->{switches}{'clear-cache'})
|
|
|
|
{
|
|
|
|
# Yes.
|
|
|
|
my $shell_call = $anvil->data->{path}{exe}{dnf}." clean all";
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { shell_call => $shell_call }});
|
|
|
|
my ($output, $return_code) = $anvil->System->call({shell_call => $shell_call});
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
output => $output,
|
|
|
|
return_code => $return_code,
|
|
|
|
}});
|
|
|
|
update_progress($anvil, 5, "message_0316");
|
|
|
|
}
|
|
|
|
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
# Before we start, do we need to remove our locally build DRBD kernel modules?
|
2023-07-24 01:40:49 +00:00
|
|
|
my $package_changes = 0;
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
my $remove_drbd_kmod = 0;
|
|
|
|
my $shell_call = $anvil->data->{path}{exe}{dnf}." check-update";
|
|
|
|
open (my $file_handle, $shell_call." 2>&1 |") or $anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, secure => 0, priority => "err", key => "log_0014", variables => { shell_call => $shell_call, error => $! }});
|
|
|
|
while(<$file_handle>)
|
|
|
|
{
|
|
|
|
chomp;
|
2023-07-24 01:40:49 +00:00
|
|
|
my $line = $anvil->Words->clean_spaces({string => $_});
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { line => $line }});
|
|
|
|
|
|
|
|
if (($line =~ /kmod-drbd/) or ($line =~ /kernel/))
|
|
|
|
{
|
|
|
|
# Looks like it.
|
|
|
|
$remove_drbd_kmod = 1;
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { remove_drbd_kmod => $remove_drbd_kmod }});
|
|
|
|
last;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
close $file_handle;
|
|
|
|
|
|
|
|
# So, shall we?
|
|
|
|
if ($remove_drbd_kmod)
|
|
|
|
{
|
2023-07-24 01:40:49 +00:00
|
|
|
# Yes, remove
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
update_progress($anvil, $progress++, "message_0320");
|
|
|
|
my $versions_to_remove = "";
|
|
|
|
my $shell_call = $anvil->data->{path}{exe}{dnf}." list installed";
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { shell_call => $shell_call }});
|
|
|
|
|
|
|
|
my ($output, $return_code) = $anvil->System->call({shell_call => $shell_call});
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
output => $output,
|
|
|
|
return_code => $return_code,
|
|
|
|
}});
|
|
|
|
foreach my $line (split/\n/, $output)
|
|
|
|
{
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { line => $line }});
|
|
|
|
if ($line =~ /(kmod-drbd-\d+.*?)\s/)
|
|
|
|
{
|
|
|
|
$versions_to_remove .= $1." ";
|
2023-07-24 01:40:49 +00:00
|
|
|
$package_changes++;
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
versions_to_remove => $versions_to_remove,
|
|
|
|
package_changes => $package_changes,
|
|
|
|
}});
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Now remove those packages.
|
|
|
|
update_progress($anvil, $progress++, "message_0321");
|
|
|
|
$shell_call = $anvil->data->{path}{exe}{dnf}." -y remove ".$versions_to_remove;
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { shell_call => $shell_call }});
|
|
|
|
|
2023-07-24 01:40:49 +00:00
|
|
|
open ($file_handle, $shell_call." 2>&1 |") or $anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, secure => 0, priority => "err", key => "log_0014", variables => { shell_call => $shell_call, error => $! }});
|
|
|
|
while(<$file_handle>)
|
|
|
|
{
|
|
|
|
chomp;
|
|
|
|
my $line = $anvil->Words->clean_spaces({string => $_});
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { line => $line }});
|
|
|
|
}
|
|
|
|
close $file_handle;
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
}
|
|
|
|
|
2018-08-14 07:45:36 +00:00
|
|
|
# NOTE: We run this directly to better monitor progress and update the progress.
|
2018-08-29 23:52:05 +00:00
|
|
|
my $transaction_shown = 0;
|
|
|
|
my $success = 0;
|
|
|
|
my $to_update = 0;
|
|
|
|
my $percent_step = 0;
|
|
|
|
my $counted_lines = 0;
|
|
|
|
my $next_step = 0;
|
|
|
|
my $verifying = 0;
|
|
|
|
my $output = "";
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
$shell_call = $anvil->data->{path}{exe}{dnf}." -y update; ".$anvil->data->{path}{exe}{echo}." return_code:\$?";
|
2018-09-07 05:29:43 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { shell_call => $shell_call }});
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
open ($file_handle, $shell_call." 2>&1 |") or $anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, secure => 0, priority => "err", key => "log_0014", variables => { shell_call => $shell_call, error => $! }});
|
2018-08-14 07:45:36 +00:00
|
|
|
while(<$file_handle>)
|
|
|
|
{
|
|
|
|
chomp;
|
|
|
|
my $line = $_;
|
|
|
|
$output .= $line."\n";
|
|
|
|
$line = $anvil->Words->clean_spaces({string => $line});
|
2018-09-01 17:08:24 +00:00
|
|
|
$anvil->data->{counts}{lines}++;
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { "counts::lines" => $anvil->data->{counts}{lines}, line => $line }});
|
2018-08-13 22:25:48 +00:00
|
|
|
|
2018-08-30 07:31:52 +00:00
|
|
|
# If there were no updates, let the user know.
|
|
|
|
if ($line =~ /^Nothing to do/i)
|
|
|
|
{
|
|
|
|
update_progress($anvil, 95, "message_0057");
|
|
|
|
}
|
|
|
|
|
2018-08-22 06:16:56 +00:00
|
|
|
if ((not $verifying) && ($line =~ /^Verifying /i))
|
|
|
|
{
|
|
|
|
# Update done, verifying now.
|
|
|
|
$verifying = 1;
|
2023-07-24 01:40:49 +00:00
|
|
|
update_progress($anvil, $progress++, "message_0038");
|
2018-08-22 06:16:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($line =~ /Running transaction/i)
|
|
|
|
{
|
|
|
|
# Done downloading
|
2018-08-29 23:52:05 +00:00
|
|
|
if (not $transaction_shown)
|
|
|
|
{
|
2023-07-24 01:40:49 +00:00
|
|
|
update_progress($anvil, $progress++, "message_0037");
|
2018-08-29 23:52:05 +00:00
|
|
|
$transaction_shown = 1;
|
|
|
|
}
|
2018-08-14 07:45:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($line =~ /return_code:(\d+)$/)
|
|
|
|
{
|
|
|
|
my $return_code = $1;
|
2018-09-07 05:29:43 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { return_code => $return_code }});
|
2018-08-14 07:45:36 +00:00
|
|
|
if ($return_code == 0)
|
|
|
|
{
|
|
|
|
$success = 1;
|
2018-09-07 05:29:43 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { success => $success }});
|
2018-08-14 07:45:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-24 01:40:49 +00:00
|
|
|
if (($line =~ / (\d+) Packages$/i) or ($line =~ / (\d+) Package$/i))
|
2018-08-14 07:45:36 +00:00
|
|
|
{
|
2023-07-17 00:45:47 +00:00
|
|
|
my $counted_lines = $1;
|
|
|
|
$package_changes = $counted_lines;
|
|
|
|
$to_update += $counted_lines;
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
package_changes => $package_changes,
|
|
|
|
counted_lines => $counted_lines,
|
|
|
|
to_update => $to_update,
|
2018-08-14 07:45:36 +00:00
|
|
|
}});
|
|
|
|
}
|
|
|
|
|
2018-08-22 06:16:56 +00:00
|
|
|
if ($line =~ /Total download size: (.*)$/i)
|
2018-08-14 07:45:36 +00:00
|
|
|
{
|
2018-08-22 06:16:56 +00:00
|
|
|
my $update_size = $1;
|
2018-09-17 19:34:43 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { update_size => $update_size }});
|
2018-08-22 06:16:56 +00:00
|
|
|
|
2018-08-14 07:45:36 +00:00
|
|
|
# Ready to install, update to 5%. The next step will count up to 95%.
|
2023-07-24 01:40:49 +00:00
|
|
|
update_progress($anvil, $progress++, "message_0035,!!size!$update_size!!");
|
2018-08-14 07:45:36 +00:00
|
|
|
|
|
|
|
# The total (reliable) count of events is (to_update * 3), counting '(x/y): '
|
2018-08-15 07:01:13 +00:00
|
|
|
# (download), 'Upgrading '/'Installing ' and 'Verifying '. We ignore the scriplet
|
2018-08-14 07:45:36 +00:00
|
|
|
# and other lines as it's hard to predict how many there will be, and they pass fast
|
|
|
|
# enough to not really matter for a progress bar.
|
2018-08-15 07:01:13 +00:00
|
|
|
$to_update *= 4;
|
|
|
|
$percent_step = $anvil->Convert->round({number => ($to_update / 90)});
|
|
|
|
$next_step = $percent_step;
|
2018-09-17 19:34:43 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
2018-08-14 07:45:36 +00:00
|
|
|
to_update => $to_update,
|
|
|
|
percent_step => $percent_step,
|
2018-08-15 07:01:13 +00:00
|
|
|
next_step => $next_step,
|
2018-08-14 07:45:36 +00:00
|
|
|
}});
|
|
|
|
}
|
|
|
|
|
|
|
|
# If 'percent_step' is set, we're ready to start counting lines.
|
2018-08-15 07:01:13 +00:00
|
|
|
if (($percent_step) && (($line =~ /\(\d+\/\d+\): /) or ($line =~ /^Upgrading /i) or ($line =~ /^Installing /) or ($line =~ /^Cleanup /i) or ($line =~ /^Verifying /i)))
|
2018-08-14 07:45:36 +00:00
|
|
|
{
|
|
|
|
$counted_lines++;
|
2018-09-07 05:29:43 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { counted_lines => $counted_lines }});
|
2018-08-14 07:45:36 +00:00
|
|
|
|
2018-09-01 17:08:24 +00:00
|
|
|
if ($line =~ /\(\d+\/\d+\): /)
|
|
|
|
{
|
|
|
|
$anvil->data->{counts}{downloaded}++;
|
2018-09-07 05:29:43 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { "counts::downloaded" => $anvil->data->{counts}{downloaded} }});
|
2018-09-01 17:08:24 +00:00
|
|
|
}
|
|
|
|
if (($line =~ /^Upgrading /i) or ($line =~ /^Installing /))
|
|
|
|
{
|
|
|
|
$anvil->data->{counts}{installed}++;
|
2018-09-07 05:29:43 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { "counts::installed" => $anvil->data->{counts}{installed} }});
|
2018-09-01 17:08:24 +00:00
|
|
|
}
|
|
|
|
if ($line =~ /^Verifying /i)
|
|
|
|
{
|
|
|
|
$anvil->data->{counts}{verified}++;
|
2018-09-07 05:29:43 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { "counts::verified" => $anvil->data->{counts}{verified} }});
|
2018-09-01 17:08:24 +00:00
|
|
|
}
|
|
|
|
|
2018-08-14 07:45:36 +00:00
|
|
|
if ($counted_lines > $next_step)
|
|
|
|
{
|
|
|
|
# Step up the progress.
|
|
|
|
$next_step += $percent_step;
|
|
|
|
$progress++;
|
2018-08-15 07:01:13 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => {
|
2018-08-14 07:45:36 +00:00
|
|
|
next_step => $next_step,
|
|
|
|
progress => $progress,
|
|
|
|
}});
|
2018-09-07 05:29:43 +00:00
|
|
|
$progress = 95 if $progress > 95;
|
2018-08-14 07:45:36 +00:00
|
|
|
|
2018-08-22 06:16:56 +00:00
|
|
|
update_progress($anvil, $progress, "");
|
2018-08-14 07:45:36 +00:00
|
|
|
}
|
|
|
|
}
|
2018-09-03 06:35:25 +00:00
|
|
|
|
|
|
|
# Update the progress if it's been more than a second since the last update.
|
|
|
|
if (time > $anvil->data->{sys}{last_update})
|
|
|
|
{
|
2018-09-07 05:29:43 +00:00
|
|
|
$progress = 95 if $progress > 95;
|
2018-09-03 06:35:25 +00:00
|
|
|
update_progress($anvil, $progress, "");
|
|
|
|
}
|
2018-08-14 07:45:36 +00:00
|
|
|
}
|
|
|
|
close $file_handle;
|
2018-08-13 22:25:48 +00:00
|
|
|
|
2018-09-01 04:59:14 +00:00
|
|
|
# Reload daemons to pick up any changed systemctl daemons.
|
2023-07-24 01:40:49 +00:00
|
|
|
$shell_call = $anvil->data->{path}{exe}{systemctl}." daemon-reload";
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { shell_call => $shell_call }});
|
|
|
|
my ($systemctl_output, $return_code) = $anvil->System->call({shell_call => $shell_call});
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { systemctl_output => $systemctl_output, return_code => $return_code }});
|
2018-09-01 04:59:14 +00:00
|
|
|
|
2023-07-15 02:29:07 +00:00
|
|
|
### See if the kernel has been updated.
|
|
|
|
# Get the newest installed kernel
|
2023-07-15 02:52:51 +00:00
|
|
|
$shell_call = $anvil->data->{path}{exe}{rpm}." -q kernel | ".$anvil->data->{path}{exe}{'sort'}." | ".$anvil->data->{path}{exe}{tail}." -n 1";
|
2023-07-15 02:29:07 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { shell_call => $shell_call }});
|
2023-07-15 02:52:51 +00:00
|
|
|
(my $installed_kernel, $return_code) = $anvil->System->call({shell_call => $shell_call});
|
2023-07-15 02:29:07 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
installed_kernel => $installed_kernel,
|
|
|
|
return_code => $return_code,
|
|
|
|
}});
|
|
|
|
$installed_kernel =~ s/^kernel-(\d+.\d+\.\d+-\d+)\..*$/$1/;
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { installed_kernel => $installed_kernel }});
|
|
|
|
|
|
|
|
# Get the running kernel
|
2023-07-24 04:22:43 +00:00
|
|
|
$shell_call = $anvil->data->{path}{exe}{uname}." -r";
|
2023-07-15 02:29:07 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { shell_call => $shell_call }});
|
|
|
|
(my $active_kernel, $return_code) = $anvil->System->call({shell_call => $shell_call});
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
active_kernel => $active_kernel,
|
|
|
|
return_code => $return_code,
|
|
|
|
}});
|
|
|
|
$active_kernel =~ s/(\d+.\d+\.\d+-\d+)\..*$/$1/;
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { active_kernel => $active_kernel }});
|
|
|
|
|
|
|
|
if ($installed_kernel ne $active_kernel)
|
|
|
|
{
|
|
|
|
# Reboot needed
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
$anvil->data->{sys}{reboot} = 1;
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { 'sys::reboot' => $anvil->data->{sys}{reboot} }});
|
2023-07-15 02:29:07 +00:00
|
|
|
}
|
|
|
|
|
2023-07-17 00:45:47 +00:00
|
|
|
# If we installed and packages, and '--reboot' was given, reboot anyway.
|
|
|
|
if (($package_changes) && ($anvil->data->{switches}{reboot}))
|
|
|
|
{
|
|
|
|
# Reboot needed
|
2023-07-24 04:22:43 +00:00
|
|
|
$anvil->data->{sys}{reboot} = 1;
|
The main change in this commit deals with anvil-daemon startup. During OS updates, it would pick up the queued update job and run it while the other --no-db one was still running. This could become an issue for other tasks in the future, so updated anvil-daemon to not run any jobs for the first minute after startup. Also updated it to see if an OS update is underway (given how it can start mid-RPM update, before packages like kmod-drbd are ready to build). While doing this, implemented caching of daily tasks (like agine out data, archiving data, network scans, etc) to only run once per day, period. As it was before, they would always run on anvil-daemon startup, then wait 24 hours.
Note that work has started it reworking anvil-update-system, but it is incomplete (and broken) in this commit.
Signed-off-by: digimer <mkelly@alteeve.ca>
2023-07-24 00:30:46 +00:00
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { 'sys::reboot' => $anvil->data->{sys}{reboot} }});
|
2023-07-17 00:45:47 +00:00
|
|
|
my $reboot_needed = $anvil->System->reboot_needed({set => 1});
|
|
|
|
}
|
|
|
|
|
2018-08-14 07:45:36 +00:00
|
|
|
# Did it work?
|
|
|
|
if (not $success)
|
|
|
|
{
|
|
|
|
# Nope.
|
2018-08-22 06:16:56 +00:00
|
|
|
update_progress($anvil, 0, "message_0036");
|
2018-08-14 07:45:36 +00:00
|
|
|
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, secure => 0, key => "error_0035", variables => { output => $output } });
|
2023-07-17 00:45:47 +00:00
|
|
|
sleep 5;
|
2020-06-24 04:39:56 +00:00
|
|
|
$anvil->nice_exit({exit_code => 3});
|
2018-08-14 07:45:36 +00:00
|
|
|
}
|
2018-08-13 22:25:48 +00:00
|
|
|
|
2023-07-25 16:43:28 +00:00
|
|
|
# Run anvil-version-changes.
|
|
|
|
$shell_call = $anvil->data->{path}{exe}{'anvil-version-changes'}.$anvil->Log->switches;
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => { shell_call => $shell_call }});
|
|
|
|
|
|
|
|
($output, $return_code) = $anvil->System->call({shell_call => $shell_call});
|
|
|
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 2, list => {
|
|
|
|
output => $output,
|
|
|
|
return_code => $return_code,
|
|
|
|
}});
|
|
|
|
|
2018-08-22 06:16:56 +00:00
|
|
|
return(0);
|
2018-08-13 22:25:48 +00:00
|
|
|
};
|