* Updated Database->connect() to set an 'active_uuid', and the host with that UUID will be the only one to do resyncs. This might help with frequent resyncs, which could be caused by simultaneous resyncs happening on both nodes stepping on each other. This should help with issue #276
Signed-off-by: digimer <digimer@gravitar.alteeve.com>
This commit is contained in:
parent
b8c7ca892f
commit
5fcbb1643c
@ -1739,16 +1739,26 @@ sub connect
|
|||||||
"db_status::${uuid}::active" => $anvil->data->{db_status}{$uuid}{active},
|
"db_status::${uuid}::active" => $anvil->data->{db_status}{$uuid}{active},
|
||||||
}});
|
}});
|
||||||
|
|
||||||
# Set the first ID to be the one I read from later. Alternatively, if this host is
|
# We always use the first DB we connect to, even if we're a DB ourselves. This helps
|
||||||
# local, use it.
|
# with consistency and leaves second (or third...) as backups.
|
||||||
if (($is_local) or (not $anvil->data->{sys}{database}{read_uuid}))
|
if (not $anvil->data->{sys}{database}{read_uuid})
|
||||||
{
|
{
|
||||||
$anvil->data->{sys}{database}{read_uuid} = $uuid;
|
$anvil->data->{sys}{database}{read_uuid} = $uuid;
|
||||||
$anvil->Database->read({set => $anvil->data->{cache}{database_handle}{$uuid}});
|
$anvil->Database->read({set => $anvil->data->{cache}{database_handle}{$uuid}});
|
||||||
|
|
||||||
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => $debug, list => {
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => $debug, list => {
|
||||||
"sys::database::read_uuid" => $anvil->data->{sys}{database}{read_uuid},
|
"sys::database::read_uuid" => $anvil->data->{sys}{database}{read_uuid},
|
||||||
'anvil->Database->read' => $anvil->Database->read(),
|
'anvil->Database->read' => $anvil->Database->read(),
|
||||||
|
}});
|
||||||
|
}
|
||||||
|
|
||||||
|
# Only the first database to connect will be "Active". What this means will expand
|
||||||
|
# over time. As of now, only the active DB will do resyncs.
|
||||||
|
if (not $anvil->data->{sys}{database}{active_uuid})
|
||||||
|
{
|
||||||
|
$anvil->data->{sys}{database}{active_uuid} = $uuid;
|
||||||
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => $debug, list => {
|
||||||
|
"sys::database::active_uuid" => $anvil->data->{sys}{database}{active_uuid},
|
||||||
}});
|
}});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1775,14 +1785,6 @@ sub connect
|
|||||||
push @{$successful_connections}, $uuid;
|
push @{$successful_connections}, $uuid;
|
||||||
}
|
}
|
||||||
|
|
||||||
# We always use the first DB we connect to, even if we're a DB ourselves. This helps with
|
|
||||||
# consistency and leaves second (or third...) as backups.
|
|
||||||
if (not $anvil->data->{sys}{database}{read_uuid})
|
|
||||||
{
|
|
||||||
$anvil->data->{sys}{database}{read_uuid} = $uuid;
|
|
||||||
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => $debug, list => { "sys::database::read_uuid" => $anvil->data->{sys}{database}{read_uuid} }});
|
|
||||||
}
|
|
||||||
|
|
||||||
# Before we try to connect, see if this is a local database and, if so, make sure it's setup.
|
# Before we try to connect, see if this is a local database and, if so, make sure it's setup.
|
||||||
if ($is_local)
|
if ($is_local)
|
||||||
{
|
{
|
||||||
@ -1842,7 +1844,8 @@ sub connect
|
|||||||
|
|
||||||
# Delete the information about this database. We'll try again on next
|
# Delete the information about this database. We'll try again on next
|
||||||
# ->connect().
|
# ->connect().
|
||||||
$anvil->data->{sys}{database}{read_uuid} = "" if $anvil->data->{sys}{database}{read_uuid} eq $uuid;
|
$anvil->data->{sys}{database}{active_uuid} = "" if $anvil->data->{sys}{database}{read_active} eq $uuid;
|
||||||
|
$anvil->data->{sys}{database}{read_uuid} = "" if $anvil->data->{sys}{database}{read_uuid} eq $uuid;
|
||||||
$anvil->data->{sys}{database}{connections}--;
|
$anvil->data->{sys}{database}{connections}--;
|
||||||
delete $anvil->data->{database}{$uuid};
|
delete $anvil->data->{database}{$uuid};
|
||||||
next;
|
next;
|
||||||
@ -1850,7 +1853,7 @@ sub connect
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# If we're a striker and no connections were found, start our database.
|
# If we're a striker, no connections were found, and we have peers, start our database.
|
||||||
my $configured_databases = keys %{$anvil->data->{database}};
|
my $configured_databases = keys %{$anvil->data->{database}};
|
||||||
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => $debug, list => {
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => $debug, list => {
|
||||||
local_host_type => $local_host_type,
|
local_host_type => $local_host_type,
|
||||||
@ -2186,11 +2189,16 @@ sub connect
|
|||||||
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => $debug, list => { check_for_resync => $check_for_resync }});
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => $debug, list => { check_for_resync => $check_for_resync }});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Check for behind databases only if there are 2+ DBs, we're the active DB, and we're set to do so.
|
||||||
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => $debug, list => {
|
$anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => $debug, list => {
|
||||||
"sys::database::connections" => $anvil->data->{sys}{database}{connections},
|
"sys::database::connections" => $anvil->data->{sys}{database}{connections},
|
||||||
|
"sys::database::active_uuid" => $anvil->data->{sys}{database}{active_uuid},
|
||||||
|
"sys::host_uuid" => $anvil->data->{sys}{host_uuid},
|
||||||
check_for_resync => $check_for_resync,
|
check_for_resync => $check_for_resync,
|
||||||
}});
|
}});
|
||||||
if (($anvil->data->{sys}{database}{connections} > 1) && ($check_for_resync))
|
if (($anvil->data->{sys}{database}{connections} > 1) &&
|
||||||
|
($anvil->data->{sys}{database}{active_uuid} eq $anvil->data->{sys}{host_uuid}) &&
|
||||||
|
($check_for_resync))
|
||||||
{
|
{
|
||||||
$anvil->Database->_find_behind_databases({
|
$anvil->Database->_find_behind_databases({
|
||||||
debug => $debug,
|
debug => $debug,
|
||||||
|
Loading…
Reference in New Issue
Block a user