[
https://issues.apache.org/jira/browse/ZOOKEEPER-876?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Diogo updated ZOOKEEPER-876:
----------------------------
Description:
When starting a new leadership, unnecessary snapshot transfers happen between
new leader and followers. This is so because of multiple small bugs.
1) the comparison of zxids is done based on a new proposal, instead of the last
logged zxid. (LearnerHandler.java ~ 297)
2) if follower is one zxid behind, the check of the interval of committed logs
excludes the follower. (LearnerHandler.java ~ 277)
3) the bug reported in ZOOKEEPER-874 (commitLogs are empty after recover).
was:
When starting a new leadership, unnecessary snapshot transfers happen between
new leader and followers. This is so because of multiple small bugs.
1) the comparison of zxids is done based on a new proposal, instead of the last
logged zxid. (LearnerFollower.java:310)
2) if follower is one zxid behind, the check of the interval of committed logs
excludes the follower. (LearnerFollower.java:269)
3) the bug reported in ZOOKEEPER-874 (commitLogs are empty after recover).
Affects Version/s: (was: 3.3.1)
3.4.0
> Unnecessary snapshot transfers between new leader and followers
> ---------------------------------------------------------------
>
> Key: ZOOKEEPER-876
> URL: https://issues.apache.org/jira/browse/ZOOKEEPER-876
> Project: ZooKeeper
> Issue Type: Bug
> Affects Versions: 3.4.0
> Reporter: Diogo
> Assignee: Diogo
> Priority: Minor
> Fix For: 3.4.0
>
> Attachments: ZOOKEEPER-876.patch
>
>
> When starting a new leadership, unnecessary snapshot transfers happen between
> new leader and followers. This is so because of multiple small bugs.
> 1) the comparison of zxids is done based on a new proposal, instead of the
> last logged zxid. (LearnerHandler.java ~ 297)
> 2) if follower is one zxid behind, the check of the interval of committed
> logs excludes the follower. (LearnerHandler.java ~ 277)
> 3) the bug reported in ZOOKEEPER-874 (commitLogs are empty after recover).
--
This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira