Skip to content

Commit

Permalink
Prevent the heartbeat time from going back and causing leader lease i…
Browse files Browse the repository at this point in the history
…nvalid (#5534)

* RaftPart creates a separate execution thread pool to prevent blocking rpc and raft call

* raft part use separate thread pool

* Prevent the heartbeat time from going back and causing leader lease invalid

---------

Co-authored-by: Doodle <[email protected]>
  • Loading branch information
tangyuanzhang and critical27 authored May 12, 2023
1 parent 5419140 commit 129ccf5
Showing 1 changed file with 7 additions and 3 deletions.
10 changes: 7 additions & 3 deletions src/kvstore/raftex/RaftPart.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1383,6 +1383,7 @@ bool RaftPart::handleElectionResponses(const ElectionResponses& resps,
bgWorkers_->addTask(
[self = shared_from_this(), proposedTerm] { self->onElected(proposedTerm); });
lastMsgAcceptedTime_ = 0;
lastMsgAcceptedCostMs_ = 0;
}
commitInThisTerm_ = false;
}
Expand Down Expand Up @@ -2115,9 +2116,12 @@ void RaftPart::sendHeartbeat() {
if (numSucceeded >= replica) {
VLOG(4) << idStr_ << "Heartbeat is accepted by quorum";
std::lock_guard<std::mutex> g(raftLock_);
auto now = time::WallClock::fastNowInMilliSec();
lastMsgAcceptedCostMs_ = now - startMs;
lastMsgAcceptedTime_ = now;
auto nowTime = static_cast<uint64_t>(time::WallClock::fastNowInMilliSec());
auto nowCostMs = nowTime - startMs;
if (nowTime - nowCostMs >= lastMsgAcceptedTime_ - lastMsgAcceptedCostMs_) {
lastMsgAcceptedCostMs_ = nowCostMs;
lastMsgAcceptedTime_ = nowTime;
}
}
});
}
Expand Down

0 comments on commit 129ccf5

Please sign in to comment.