You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@ratis.apache.org by "Glen Geng (Jira)" <ji...@apache.org> on 2020/07/08 03:40:00 UTC
[jira] [Commented] (RATIS-998) shouldWithholdVotes() should be
triggered for handling higher term
[ https://issues.apache.org/jira/browse/RATIS-998?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17153211#comment-17153211 ]
Glen Geng commented on RATIS-998:
---------------------------------
Together with [RATIS-981]([https://issues.apache.org/jira/projects/RATIS/issues/RATIS-981?filter=allissues],]
stale leader will step down by itself.
> shouldWithholdVotes() should be triggered for handling higher term
> ------------------------------------------------------------------
>
> Key: RATIS-998
> URL: https://issues.apache.org/jira/browse/RATIS-998
> Project: Ratis
> Issue Type: Bug
> Components: server
> Affects Versions: 0.5.0
> Reporter: Glen Geng
> Assignee: Glen Geng
> Priority: Major
>
>
> shouldWithholdVotes() should be triggered for handling higher term
>
> Current code is
> {code:java}
> private boolean shouldWithholdVotes(long candidateTerm) {
> if (state.getCurrentTerm() < candidateTerm) {
> return false;
> } else if (isLeader()) {
> return true;
> } else {
> // following a leader and not yet timeout
> return isFollower() && state.hasLeader() && role.getFollowerState().map(FollowerState::shouldWithholdVotes).orElse(false); }
> }
> {code}
> Modify to
> {code:java}
> private boolean shouldWithholdVotes(long candidateTerm) {
> if (state.getCurrentTerm() >= candidateTerm) {
> return false;
> } else if (isLeader()) {
> return true;
> } else {
> // following a leader and not yet timeout
> return isFollower() && state.hasLeader() && role.getFollowerState().map(FollowerState::shouldWithholdVotes).orElse(false); }
> }
> {code}
>
--
This message was sent by Atlassian Jira
(v8.3.4#803005)