Ignore disabled nodes

This commit is contained in:
Félix Suárez 2023-08-01 18:14:11 -06:00
parent c52539ebdc
commit 3ecf171fdb
1 changed files with 43 additions and 2 deletions

View File

@ -361,7 +361,7 @@ sub ha_load_databases($) {
return unless defined($conf->{'ha_hosts'}); return unless defined($conf->{'ha_hosts'});
@HA_DB_Hosts = grep { !/^#/ } map { s/^\s+|\s+$//g; $_; } split(/,/, $conf->{'ha_hosts'}); @HA_DB_Hosts = grep { !/^#/ } map { s/^\s+|\s+$//g; $_; } split(/,/, $conf->{'ha_hosts'});
log_message($conf, 'DEBUG', "Loaded databases from disk (@HA_DB_Hosts)"); log_message($conf, 'DEBUG', "Loaded databases from disk (@HA_DB_Hosts)");
} }
############################################################################### ###############################################################################
@ -388,9 +388,20 @@ sub ha_database_connect_pandora($) {
# Load the list of HA databases. # Load the list of HA databases.
ha_load_databases($conf); ha_load_databases($conf);
# Select a new master database. # Select a new master database.
my ($dbh, $utimestamp, $max_utimestamp) = (undef, undef, -1); my ($dbh, $utimestamp, $max_utimestamp) = (undef, undef, -1);
my @disabled_nodes = get_disabled_nodes($conf);
# If there are disabled nodes ignore them from the HA_DB_Hosts.
if(scalar @disabled_nodes ne 0){
@HA_DB_Hosts = grep { my $item = $_; !grep { $_ eq $item } @disabled_nodes } @HA_DB_Hosts;
my $data = join(",", @disabled_nodes);
log_message($conf, 'LOG', "Ignoring disabled hosts: " . $data);
}
foreach my $ha_dbhost (@HA_DB_Hosts) { foreach my $ha_dbhost (@HA_DB_Hosts) {
# Retry each database ha_connect_retries times. # Retry each database ha_connect_retries times.
@ -481,6 +492,36 @@ sub ha_restart_pandora($) {
`$config->{'pandora_service_cmd'} $control_command 2>/dev/null`; `$config->{'pandora_service_cmd'} $control_command 2>/dev/null`;
} }
###############################################################################
# Get ip of the disabled nodes.
###############################################################################
sub get_disabled_nodes($) {
my ($conf) = @_;
my $dbh = db_connect('mysql',
$conf->{'dbname'},
$conf->{'dbhost'},
$conf->{'dbport'},
$conf->{'ha_dbuser'},
$conf->{'ha_dbpass'});
my $disabled_nodes = get_db_value($dbh, "SELECT value FROM tconfig WHERE token = 'ha_disabled_nodes'");
if(!defined($disabled_nodes) || $disabled_nodes eq ""){
$disabled_nodes = ',';
}
my @disabled_nodes = split(',', $disabled_nodes);
if(scalar @disabled_nodes ne 0){
$disabled_nodes = join(",", @disabled_nodes);
@disabled_nodes = get_db_rows($dbh, "SELECT host FROM tdatabase WHERE id IN ($disabled_nodes)");
@disabled_nodes = map { $_->{host} } @disabled_nodes;
}
return @disabled_nodes;
}
############################################################################### ###############################################################################
# Main (Pacemaker) # Main (Pacemaker)
############################################################################### ###############################################################################