1
0
mirror of https://github.com/codership/wsrep-lib.git synced 2025-10-25 09:37:36 +03:00

codership/wsrep-lib#54 Service call to recover streaming appliers

Introduced server_service recover_streaming_appliers() interface
call which will be called in total order whenever streaming appliers
must be recovered. The call comes with two overloads, one which
can be called from client context (e.g. after SST has been received)
and the other from high priority context (e.g. view event handling).

The client context overload should be eventually be deprecated once
there is a mechanism to make provider signal that it has joined to
the cluster and will start applying events.
This commit is contained in:
Teemu Ollakka
2019-01-18 14:02:58 +02:00
parent 144d8c13c1
commit a6b38d2428
7 changed files with 91 additions and 2 deletions

View File

@@ -580,6 +580,10 @@ void wsrep::server_state::sst_received(wsrep::client_service& cs,
current_view_ = v;
server_service_.log_view(NULL /* this view is stored already */, v);
lock.lock();
recover_streaming_appliers_if_not_recovered(lock, cs);
lock.unlock();
}
if (provider().sst_received(gtid, error))
@@ -747,10 +751,14 @@ void wsrep::server_state::on_primary_view(
}
assert(high_priority_service);
if (high_priority_service)
{
recover_streaming_appliers_if_not_recovered(lock,
*high_priority_service);
close_orphaned_sr_transactions(lock, *high_priority_service);
}
if (server_service_.sst_before_init())
{
if (state_ == s_initialized)
@@ -1143,6 +1151,20 @@ void wsrep::server_state::interrupt_state_waiters(
cond_.notify_all();
}
template <class C>
void wsrep::server_state::recover_streaming_appliers_if_not_recovered(
wsrep::unique_lock<wsrep::mutex>& lock, C& c)
{
assert(lock.owns_lock());
if (streaming_appliers_recovered_ == false)
{
lock.unlock();
server_service_.recover_streaming_appliers(c);
lock.lock();
}
streaming_appliers_recovered_ = true;
}
void wsrep::server_state::close_orphaned_sr_transactions(
wsrep::unique_lock<wsrep::mutex>& lock,
wsrep::high_priority_service& high_priority_service)
@@ -1242,4 +1264,5 @@ void wsrep::server_state::close_transactions_at_disconnect(
streaming_appliers_.erase(i++);
server_service_.release_high_priority_service(streaming_applier);
}
streaming_appliers_recovered_ = false;
}