diff --git a/src/lib/common/homestore_config.fbs b/src/lib/common/homestore_config.fbs index 003a91606..32ba410f6 100644 --- a/src/lib/common/homestore_config.fbs +++ b/src/lib/common/homestore_config.fbs @@ -265,7 +265,8 @@ table Consensus { // Log difference to determine if the follower is in resync mode resync_log_idx_threshold: int64 = 100; - // Log difference from leader's point of view, to determine if the follower is laggy. + // Log difference from leader's point of view, to determine if the + // follower is laggy and if so, leader will stop pushing data until it drops under this threshold. laggy_threshold: int64 = 2000; } diff --git a/src/lib/replication/repl_dev/raft_repl_dev.cpp b/src/lib/replication/repl_dev/raft_repl_dev.cpp index 5f7ab15bb..883ce77e4 100644 --- a/src/lib/replication/repl_dev/raft_repl_dev.cpp +++ b/src/lib/replication/repl_dev/raft_repl_dev.cpp @@ -1031,12 +1031,12 @@ std::set< replica_id_t > RaftReplDev::get_active_peers() const { auto repl_status = get_replication_status(); std::set< replica_id_t > res; auto my_committed_idx = m_commit_upto_lsn.load(); - uint64_t lagThreshold = my_committed_idx > HS_DYNAMIC_CONFIG(consensus.laggy_threshold) + uint64_t least_active_repl_idx = my_committed_idx > HS_DYNAMIC_CONFIG(consensus.laggy_threshold) ? my_committed_idx - HS_DYNAMIC_CONFIG(consensus.laggy_threshold) : 0; for (auto p : repl_status) { if (p.id_ == m_my_repl_id) { continue; } - if (p.replication_idx_ >= lagThreshold) { + if (p.replication_idx_ >= least_active_repl_idx) { res.insert(p.id_); } else { RD_LOGW("Excluding peer {} from active_peers, lag {}, my lsn {}, peer lsn {}", p.id_,