|
|
|
#!/usr/bin/perl
|
|
|
|
#
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
use Anvil::Tools;
|
|
|
|
use Data::Dumper;
|
|
|
|
|
|
|
|
my $THIS_FILE = ($0 =~ /^.*\/(.*)$/)[0];
|
|
|
|
my $running_directory = ($0 =~ /^(.*?)\/$THIS_FILE$/)[0];
|
|
|
|
if (($running_directory =~ /^\./) && ($ENV{PWD}))
|
|
|
|
{
|
|
|
|
$running_directory =~ s/^\./$ENV{PWD}/;
|
|
|
|
}
|
|
|
|
|
|
|
|
# Turn off buffering so that the pinwheel will display while waiting for the SSH call(s) to complete.
|
|
|
|
$| = 1;
|
|
|
|
|
|
|
|
my $anvil = Anvil::Tools->new();
|
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 2, key => "log_0115", variables => { program => $THIS_FILE }});
|
|
|
|
|
|
|
|
# Read switches (target ([user@]host[:port]) and the file with the target's password.
|
|
|
|
$anvil->Get->switches;
|
|
|
|
|
|
|
|
# Connect to the database(s).
|
|
|
|
$anvil->Database->connect({debug => 3});
|
* Created Convert->fence_ipmilan_to_ipmitool() that takes a 'fence_ipmilan' call and converts it into a direct 'ipmitool' call.
* Created Database->get_power() that loads data from the special 'power' table.
* Fixed a bug in calls to Network->ping() where some weren't formatted properly for receiving two string variables.
* Updated Database->get_anvils() to record the machine types when recording host information.
* Updated Database->get_hosts_info() to also load the 'host_ipmi' column.
* Updated Database->get_upses() to store the link to the 'power' -> 'power_uuid', when available.
* Created ScanCore->call_scan_agents() that does the work of actually calling scan agents, moving the logic out from the scancore daemon.
* Created ScanCore->check_power() that takes a host and the anvil it is in and returns if it's on batteries or not. If it is, the time on batteries and estimate hold-up time is returned. If not, the highest charge percentage is returned.
* Created ScanCore->post_scan_analysis() that is a wrapper for calling the new ->post_scan_analysis_dr(), ->post_scan_analysis_node() and ->post_scan_analysis_striker(). Of which, _dr and _node are still empty, but _striker is complete.
** ->post_scan_analysis_striker() is complete. It now boots a node after a power loss if the UPSes powering it are OK (at least one has mains power, and the main-powered UPS(es) have reached the minimum charge percentage). If it's thermal, IPMI is called and so long as at least one thermal sensor is found and it/they are all OK, it is booted. For now, M2's thermal reboot delay logic hasn't been replicated, as it added a lot of complexity and didn't prove practically useful.
* Created System->collect_ipmi_data() and moved 'scan_ipmitool's ipmitool call and parse into that method. This was done to allow ScanCore->post_scan_analysis_striker() to also call IPMI on a remote machine during thermal down events without reimplementing the logic.
* Updated scan-ipmitool to only record temperature data for data collected locally. Also renamed 'machine' variables and hash keys to 'host_name' to clarify what is being stored.
* Updated scancore to clear the 'system::stop_reason' variable.
* Added missing packages to striker-manage-install-target.
Signed-off-by: Digimer <digimer@alteeve.ca>
4 years ago
|
|
|
$anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 2, key => "log_0132"});
|
|
|
|
|
|
|
|
my $key_string = 'message_0190
|
|
|
|
job_0185
|
|
|
|
job_0186,!!minor!5!!,!!port!7803!!
|
|
|
|
job_0188,!!job_uuid!12eeded2-c5bb-4295-8c8e-665bd9c9b83a!!,!!peer_name!mk-a02n01.digimer.ca!!
|
|
|
|
job_0189,!!lv_path!/dev/mk-a02n02_ssd0/srv02-lab02_0!!
|
|
|
|
job_0218
|
|
|
|
job_0190,!!resource!srv02-lab02!!
|
|
|
|
job_0191,!!resource!srv02-lab02!!
|
|
|
|
job_0192
|
|
|
|
job_0195
|
|
|
|
job_0203,!!resource!srv02-lab02!!
|
|
|
|
job_0199,!!shell_call!/usr/bin/virt-install --connect qemu:///system \
|
|
|
|
--name srv02-lab02 \
|
|
|
|
--os-variant win2k19 \
|
|
|
|
--memory 8192 \
|
|
|
|
--events on_poweroff=destroy,on_reboot=restart \
|
|
|
|
--vcpus 6,sockets=1,cores=6 \
|
|
|
|
--cpu host \
|
|
|
|
--network bridge=ifn1_bridge1,model=virtio \
|
|
|
|
--graphics spice \
|
|
|
|
--sound ich9 \
|
|
|
|
--clock offset=localtime \
|
|
|
|
--boot menu=on \
|
|
|
|
--disk path=/dev/drbd/by-res/srv02-lab02/0,target.bus=virtio,driver.io=threads,cache=writeback,driver.discard=unmap,boot.order=1 \
|
|
|
|
--disk path=/mnt/shared/files/Windows_Server_2019_eval.iso,device=cdrom,shareable=on,boot.order=2 \
|
|
|
|
--disk path=/mnt/shared/files/virtio-win-0.1.185.iso,device=cdrom,shareable=on,boot.order=3 --force \
|
|
|
|
--noautoconsole --wait -1 > /var/log/anvil-server_srv02-lab02.log
|
|
|
|
!!
|
|
|
|
job_0200';
|
|
|
|
my ($free_minor, $free_port) = $anvil->Words->parse_banged_string({
|
|
|
|
debug => 2,
|
|
|
|
key_string => $key_string,
|
|
|
|
});
|
|
|
|
|
|
|
|
$anvil->nice_exit({exit_code => 0});
|