[Tarantool-patches] [PATCH v3 12/12] replication: send current Raft term in join response
Serge Petrenko
sergepetrenko at tarantool.org
Tue Jun 29 01:12:58 MSK 2021
Make Raft nodes send out their latest persisted term to joining
replicas.
Follow-up #6034
---
src/box/applier.cc | 5 +++++
src/box/relay.cc | 6 ++++++
2 files changed, 11 insertions(+)
diff --git a/src/box/applier.cc b/src/box/applier.cc
index 482b9446a..978383e64 100644
--- a/src/box/applier.cc
+++ b/src/box/applier.cc
@@ -459,6 +459,11 @@ applier_wait_snapshot(struct applier *applier)
if (xrow_decode_synchro(&row, &req) != 0)
diag_raise();
txn_limbo_process(&txn_limbo, &req);
+ } else if (iproto_type_is_raft_request(row.type)) {
+ struct raft_request req;
+ if (xrow_decode_raft(&row, &req, NULL) != 0)
+ diag_raise();
+ box_raft_recover(&req);
} else if (row.type != IPROTO_JOIN_SNAPSHOT) {
tnt_raise(ClientError, ER_UNKNOWN_REQUEST_TYPE,
(uint32_t)row.type);
diff --git a/src/box/relay.cc b/src/box/relay.cc
index 4b102a777..70f1a045b 100644
--- a/src/box/relay.cc
+++ b/src/box/relay.cc
@@ -428,7 +428,9 @@ relay_initial_join(int fd, uint64_t sync, struct vclock *vclock,
diag_raise();
struct synchro_request req;
+ struct raft_request raft_req;
txn_limbo_checkpoint(&txn_limbo, &req);
+ box_raft_checkpoint_local(&raft_req);
/* Respond to the JOIN request with the current vclock. */
struct xrow_header row;
@@ -451,6 +453,10 @@ relay_initial_join(int fd, uint64_t sync, struct vclock *vclock,
row.sync = sync;
coio_write_xrow(&relay->io, &row);
+ xrow_encode_raft(&row, &fiber()->gc, &raft_req);
+ row.sync = sync;
+ coio_write_xrow(&relay->io, &row);
+
/* Mark the end of the metadata stream. */
row.type = IPROTO_JOIN_SNAPSHOT;
coio_write_xrow(&relay->io, &row);
--
2.30.1 (Apple Git-130)
More information about the Tarantool-patches
mailing list