2018-04-03 22:19:17 +08:00
|
|
|
#include "distributed/cluster_discovery_worker.hpp"
|
|
|
|
#include "distributed/coordination_rpc_messages.hpp"
|
|
|
|
|
|
|
|
namespace distributed {
|
|
|
|
using Server = communication::rpc::Server;
|
|
|
|
|
|
|
|
ClusterDiscoveryWorker::ClusterDiscoveryWorker(
|
|
|
|
Server &server, WorkerCoordination &coordination,
|
|
|
|
communication::rpc::ClientPool &client_pool)
|
|
|
|
: server_(server), coordination_(coordination), client_pool_(client_pool) {
|
|
|
|
server_.Register<ClusterDiscoveryRpc>([this](const ClusterDiscoveryReq &req) {
|
|
|
|
this->coordination_.RegisterWorker(req.worker_id, req.endpoint);
|
|
|
|
return std::make_unique<ClusterDiscoveryRes>();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-04-10 19:07:01 +08:00
|
|
|
void ClusterDiscoveryWorker::RegisterWorker(int worker_id) {
|
|
|
|
auto result =
|
|
|
|
client_pool_.Call<RegisterWorkerRpc>(worker_id, server_.endpoint());
|
2018-04-03 22:19:17 +08:00
|
|
|
CHECK(result) << "RegisterWorkerRpc failed";
|
2018-05-09 19:26:22 +08:00
|
|
|
CHECK(result->registration_successful)
|
|
|
|
<< "Unable to assign requested ID (" << worker_id << ") to worker!";
|
2018-04-03 22:19:17 +08:00
|
|
|
|
2018-05-09 19:26:22 +08:00
|
|
|
worker_id_ = worker_id;
|
2018-04-03 22:19:17 +08:00
|
|
|
for (auto &kv : result->workers) {
|
|
|
|
coordination_.RegisterWorker(kv.first, kv.second);
|
|
|
|
}
|
2018-04-16 16:43:16 +08:00
|
|
|
recovery_info_ = result->recovery_info;
|
2018-04-03 22:19:17 +08:00
|
|
|
}
|
|
|
|
|
2018-05-09 19:26:22 +08:00
|
|
|
void ClusterDiscoveryWorker::NotifyWorkerRecovered() {
|
|
|
|
CHECK(worker_id_ >= 0)
|
|
|
|
<< "Workers id is not yet assigned, preform registration before "
|
|
|
|
"notifying that the recovery finished";
|
|
|
|
auto result = client_pool_.Call<NotifyWorkerRecoveredRpc>(worker_id_);
|
|
|
|
CHECK(result) << "NotifyWorkerRecoveredRpc failed";
|
|
|
|
}
|
|
|
|
|
2018-04-03 22:19:17 +08:00
|
|
|
} // namespace distributed
|