Class Leader
- java.lang.Object
- 
- org.apache.zookeeper.server.quorum.LearnerMaster
- 
- org.apache.zookeeper.server.quorum.Leader
 
 
- 
 public class Leader extends LearnerMaster This class has the control logic for the Leader.
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classLeader.Proposalstatic classLeader.XidRolloverException
 - 
Field SummaryFields Modifier and Type Field Description static intACKEPOCHThis message is used by the follow to ack a proposed epoch.protected Set<Long>connectingFollowersprotected Set<Long>electingFollowersprotected booleanelectionFinishedstatic intLEADERINFOThis message is the first that a follower receives from the leader.static StringMAX_TIME_TO_WAIT_FOR_EPOCHprotected Leader.ProposalnewLeaderProposalstatic intPROPOSALThis message type is sent by a leader to propose a mutation.protected booleanquorumFormed
 - 
Constructor SummaryConstructors Constructor Description Leader(QuorumPeer self, LeaderZooKeeperServer zk)
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddLearnerHandler(LearnerHandler learner)Adds peer to the leader.static QuorumPacketbuildInformAndActivePacket(long zxid, long designatedLeader, byte[] proposalData)voidcommit(long zxid)Create a commit packet and send it to all the members of the quorumvoidcommitAndActivate(long zxid, long designatedLeader)static intgetAckLoggingFrequency()longgetAndDecrementFollowerCounter()intgetCurrentTick()longgetEpoch()Returns the current epoch of the leader.longgetEpochToPropose(long sid, long lastAcceptedEpoch)List<LearnerHandler>getForwardingFollowers()Returns a copy of the current forwarding follower snapshotlonggetLastProposed()List<LearnerHandler>getLearners()Returns a copy of the current learner snapshotList<LearnerHandler>getNonVotingFollowers()intgetNumPendingSyncs()List<LearnerHandler>getObservingLearners()Returns a copy of the current observer snapshotIterable<Map<String,Object>>getObservingLearnersInfo()static StringgetPacketType(int packetType)Get string representation of a given packet typeStringgetPeerInfo(long sid)BufferStatsgetProposalStats()QuorumAuthServergetQuorumAuthServer()byte[]getQuorumVerifierBytes()longgetQuorumVerifierVersion()intgetTickOfInitialAckDeadline()intgetTickOfNextAckDeadline()longgetUptime()ZKDatabasegetZKDatabase()voidinform(Leader.Proposal proposal)Create an inform packet and send it to all observers.voidinformAndActivate(Leader.Proposal proposal, long designatedLeader)Create an inform and activate packet and send it to all observers.booleanisQuorumSynced(QuorumVerifier qv)Returns true if a quorum in qv is connected and synced with the leader and false otherwisevoidprocessAck(long sid, long zxid, SocketAddress followerAddr)Keep a count of acks that are received by the leader for a particular proposalvoidprocessSync(LearnerSyncRequest r)Process sync requestsLeader.Proposalpropose(Request request)create a proposal and send it out to all the membersvoidregisterLearnerHandlerBean(LearnerHandler learnerHandler, Socket socket)voidremoveLearnerHandler(LearnerHandler peer)Remove the learner from the learner listvoidreportLookingSid(long sid)voidresetObserverConnectionStats()voidrevalidateSession(QuorumPacket qp, LearnerHandler learnerHandler)voidsendSync(LearnerSyncRequest r)Sends a sync message to the appropriate serverstatic voidsetAckLoggingFrequency(int frequency)voidsetLeadingVoteSet(SyncedLearnerTracker voteSet)static voidsetMaxTimeToWaitForEpoch(int maxTimeToWaitForEpoch)longstartForwarding(LearnerHandler handler, long lastSeenZxid)lets the leader know that a follower is capable of following and is done syncingvoidsubmitLearnerRequest(Request si)intsyncTimeout()voidtouch(long sess, int to)booleantryToCommit(Leader.Proposal p, long zxid, SocketAddress followerAddr)voidunregisterLearnerHandlerBean(LearnerHandler learnerHandler)voidwaitForEpochAck(long id, StateSummary ss)voidwaitForNewLeaderAck(long sid, long zxid)Process NEWLEADER ack of a given sid and wait until the leader receives sufficient acks.voidwaitForStartup()- 
Methods inherited from class org.apache.zookeeper.server.quorum.LearnerMastergetLearnerDiffSyncThrottler, getLearnerSnapSyncThrottler, getMaxConcurrentDiffSyncs, getMaxConcurrentSnapSyncs, setMaxConcurrentDiffSyncs, setMaxConcurrentSnapSyncs
 
- 
 
- 
- 
- 
Field Detail- 
quorumFormedprotected boolean quorumFormed 
 - 
LEADERINFOpublic static final int LEADERINFO This message is the first that a follower receives from the leader. It has the protocol version and the epoch of the leader.- See Also:
- Constant Field Values
 
 - 
ACKEPOCHpublic static final int ACKEPOCH This message is used by the follow to ack a proposed epoch.- See Also:
- Constant Field Values
 
 - 
PROPOSALpublic static final int PROPOSAL This message type is sent by a leader to propose a mutation.- See Also:
- Constant Field Values
 
 - 
newLeaderProposalprotected final Leader.Proposal newLeaderProposal 
 - 
MAX_TIME_TO_WAIT_FOR_EPOCHpublic static final String MAX_TIME_TO_WAIT_FOR_EPOCH - See Also:
- Constant Field Values
 
 - 
electionFinishedprotected boolean electionFinished 
 
- 
 - 
Constructor Detail- 
Leaderpublic Leader(QuorumPeer self, LeaderZooKeeperServer zk) throws IOException - Throws:
- IOException
 
 
- 
 - 
Method Detail- 
setAckLoggingFrequencypublic static void setAckLoggingFrequency(int frequency) 
 - 
getAckLoggingFrequencypublic static int getAckLoggingFrequency() 
 - 
getProposalStatspublic BufferStats getProposalStats() 
 - 
getLearnerspublic List<LearnerHandler> getLearners() Returns a copy of the current learner snapshot
 - 
getForwardingFollowerspublic List<LearnerHandler> getForwardingFollowers() Returns a copy of the current forwarding follower snapshot
 - 
getNonVotingFollowerspublic List<LearnerHandler> getNonVotingFollowers() 
 - 
getObservingLearnerspublic List<LearnerHandler> getObservingLearners() Returns a copy of the current observer snapshot
 - 
resetObserverConnectionStatspublic void resetObserverConnectionStats() 
 - 
getNumPendingSyncspublic int getNumPendingSyncs() 
 - 
addLearnerHandlerpublic void addLearnerHandler(LearnerHandler learner) Adds peer to the leader.- Parameters:
- learner- instance of learner handle
 
 - 
removeLearnerHandlerpublic void removeLearnerHandler(LearnerHandler peer) Remove the learner from the learner list- Parameters:
- peer-
 
 - 
isQuorumSyncedpublic boolean isQuorumSynced(QuorumVerifier qv) Returns true if a quorum in qv is connected and synced with the leader and false otherwise- Parameters:
- qv- is a QuorumVerifier
 
 - 
getUptimepublic long getUptime() 
 - 
tryToCommitpublic boolean tryToCommit(Leader.Proposal p, long zxid, SocketAddress followerAddr) - Returns:
- True if committed, otherwise false.
 
 - 
processAckpublic void processAck(long sid, long zxid, SocketAddress followerAddr)Keep a count of acks that are received by the leader for a particular proposal- Parameters:
- sid- is the id of the server that sent the ack
- zxid- is the zxid of the proposal sent out
- followerAddr-
 
 - 
commitpublic void commit(long zxid) Create a commit packet and send it to all the members of the quorum- Parameters:
- zxid-
 
 - 
commitAndActivatepublic void commitAndActivate(long zxid, long designatedLeader)
 - 
informpublic void inform(Leader.Proposal proposal) Create an inform packet and send it to all observers.
 - 
buildInformAndActivePacketpublic static QuorumPacket buildInformAndActivePacket(long zxid, long designatedLeader, byte[] proposalData) 
 - 
informAndActivatepublic void informAndActivate(Leader.Proposal proposal, long designatedLeader) Create an inform and activate packet and send it to all observers.
 - 
getLastProposedpublic long getLastProposed() 
 - 
getEpochpublic long getEpoch() Returns the current epoch of the leader.
 - 
proposepublic Leader.Proposal propose(Request request) throws Leader.XidRolloverException create a proposal and send it out to all the members- Parameters:
- request-
- Returns:
- the proposal that is queued to send to all the members
- Throws:
- Leader.XidRolloverException
 
 - 
processSyncpublic void processSync(LearnerSyncRequest r) Process sync requests- Parameters:
- r- the request
 
 - 
sendSyncpublic void sendSync(LearnerSyncRequest r) Sends a sync message to the appropriate server
 - 
startForwardingpublic long startForwarding(LearnerHandler handler, long lastSeenZxid) lets the leader know that a follower is capable of following and is done syncing- Parameters:
- handler- handler of the follower
- Returns:
- last proposed zxid
 
 - 
waitForStartuppublic void waitForStartup() throws InterruptedException- Throws:
- InterruptedException
 
 - 
setMaxTimeToWaitForEpochpublic static void setMaxTimeToWaitForEpoch(int maxTimeToWaitForEpoch) 
 - 
setLeadingVoteSetpublic void setLeadingVoteSet(SyncedLearnerTracker voteSet) 
 - 
reportLookingSidpublic void reportLookingSid(long sid) 
 - 
getEpochToProposepublic long getEpochToPropose(long sid, long lastAcceptedEpoch) throws InterruptedException, IOException- Throws:
- InterruptedException
- IOException
 
 - 
getZKDatabasepublic ZKDatabase getZKDatabase() 
 - 
waitForEpochAckpublic void waitForEpochAck(long id, StateSummary ss) throws IOException, InterruptedException- Throws:
- IOException
- InterruptedException
 
 - 
waitForNewLeaderAckpublic void waitForNewLeaderAck(long sid, long zxid) throws InterruptedExceptionProcess NEWLEADER ack of a given sid and wait until the leader receives sufficient acks.- Parameters:
- sid-
- Throws:
- InterruptedException
 
 - 
getPacketTypepublic static String getPacketType(int packetType) Get string representation of a given packet type- Parameters:
- packetType-
- Returns:
- string representing the packet type
 
 - 
getCurrentTickpublic int getCurrentTick() 
 - 
syncTimeoutpublic int syncTimeout() 
 - 
getTickOfNextAckDeadlinepublic int getTickOfNextAckDeadline() 
 - 
getTickOfInitialAckDeadlinepublic int getTickOfInitialAckDeadline() 
 - 
getAndDecrementFollowerCounterpublic long getAndDecrementFollowerCounter() 
 - 
touchpublic void touch(long sess, int to)
 - 
submitLearnerRequestpublic void submitLearnerRequest(Request si) 
 - 
getQuorumVerifierVersionpublic long getQuorumVerifierVersion() 
 - 
getPeerInfopublic String getPeerInfo(long sid) 
 - 
getQuorumVerifierBytespublic byte[] getQuorumVerifierBytes() 
 - 
getQuorumAuthServerpublic QuorumAuthServer getQuorumAuthServer() 
 - 
revalidateSessionpublic void revalidateSession(QuorumPacket qp, LearnerHandler learnerHandler) throws IOException - Throws:
- IOException
 
 - 
registerLearnerHandlerBeanpublic void registerLearnerHandlerBean(LearnerHandler learnerHandler, Socket socket) 
 - 
unregisterLearnerHandlerBeanpublic void unregisterLearnerHandlerBean(LearnerHandler learnerHandler) 
 
- 
 
-