Class Learner
- java.lang.Object
- 
- org.apache.zookeeper.server.quorum.Learner
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected BufferedOutputStreambufferedOutputstatic booleancloseSocketAsyncprotected MultipleAddressesleaderAddrprotected InputArchiveleaderIsprotected OutputArchiveleaderOsprotected intleaderProtocolVersionthe protocol version of the leaderstatic StringLEARNER_ASYNC_SENDINGstatic StringLEARNER_CLOSE_SOCKET_ASYNCprotected static org.slf4j.LoggerLOGprotected MessageTrackermessageTrackerprotected Socketsockprotected AtomicBooleansockBeingClosed
 - 
Constructor SummaryConstructors Constructor Description Learner()
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidconnectToLeader(MultipleAddresses multiAddr, String hostname)Establish a connection with the LearnerMaster found by findLearnerMaster.protected SocketcreateSocket()Creating a simple or and SSL socket.protected QuorumPeer.QuorumServerfindLeader()Returns the address of the node we think is the leader.protected static booleangetAsyncSending()intgetPendingRevalidationsCount()SocketgetSocket()Socket getterprotected longnanoTime()Overridable helper method to return the System.nanoTime().protected voidping(QuorumPacket qp)protected longregisterWithLeader(int pktType)Once connected to the leader or learner master, perform the handshake protocol to establish a following / observing connection.protected voidrevalidate(QuorumPacket qp)protected static voidsetAsyncSending(boolean newMode)voidshutdown()Shutdown the Peerprotected voidsockConnect(Socket sock, InetSocketAddress addr, int timeout)Overridable helper method to simply call sock.connect().protected voidstartSendingThread()Start thread that will forward any packet in the queue to the leaderprotected voidsyncWithLeader(long newLeaderZxid)Finally, synchronize our history with the Leader (if Follower) or the LearnerMaster (if Observer).
 
- 
- 
- 
Field Detail- 
bufferedOutputprotected BufferedOutputStream bufferedOutput 
 - 
sockprotected Socket sock 
 - 
leaderAddrprotected MultipleAddresses leaderAddr 
 - 
sockBeingClosedprotected AtomicBoolean sockBeingClosed 
 - 
leaderIsprotected InputArchive leaderIs 
 - 
leaderOsprotected OutputArchive leaderOs 
 - 
leaderProtocolVersionprotected int leaderProtocolVersion the protocol version of the leader
 - 
messageTrackerprotected final MessageTracker messageTracker 
 - 
LOGprotected static final org.slf4j.Logger LOG 
 - 
LEARNER_ASYNC_SENDINGpublic static final String LEARNER_ASYNC_SENDING - See Also:
- Constant Field Values
 
 - 
LEARNER_CLOSE_SOCKET_ASYNCpublic static final String LEARNER_CLOSE_SOCKET_ASYNC - See Also:
- Constant Field Values
 
 - 
closeSocketAsyncpublic static final boolean closeSocketAsync 
 
- 
 - 
Method Detail- 
getSocketpublic Socket getSocket() Socket getter
 - 
getPendingRevalidationsCountpublic int getPendingRevalidationsCount() 
 - 
setAsyncSendingprotected static void setAsyncSending(boolean newMode) 
 - 
getAsyncSendingprotected static boolean getAsyncSending() 
 - 
startSendingThreadprotected void startSendingThread() Start thread that will forward any packet in the queue to the leader
 - 
findLeaderprotected QuorumPeer.QuorumServer findLeader() Returns the address of the node we think is the leader.
 - 
nanoTimeprotected long nanoTime() Overridable helper method to return the System.nanoTime(). This method behaves identical to System.nanoTime().
 - 
sockConnectprotected void sockConnect(Socket sock, InetSocketAddress addr, int timeout) throws IOException Overridable helper method to simply call sock.connect(). This can be overriden in tests to fake connection success/failure for connectToLeader.- Throws:
- IOException
 
 - 
connectToLeaderprotected void connectToLeader(MultipleAddresses multiAddr, String hostname) throws IOException Establish a connection with the LearnerMaster found by findLearnerMaster. Followers only connect to Leaders, Observers can connect to any active LearnerMaster. Retries until either initLimit time has elapsed or 5 tries have happened.- Parameters:
- multiAddr- - the address of the Peer to connect to.
- Throws:
- IOException- - if the socket connection fails on the 5th attempt if there is an authentication failure while connecting to leader
 
 - 
createSocketprotected Socket createSocket() throws X509Exception, IOException Creating a simple or and SSL socket. This can be overridden in tests to fake already connected sockets for connectToLeader.- Throws:
- X509Exception
- IOException
 
 - 
registerWithLeaderprotected long registerWithLeader(int pktType) throws IOExceptionOnce connected to the leader or learner master, perform the handshake protocol to establish a following / observing connection.- Parameters:
- pktType-
- Returns:
- the zxid the Leader sends for synchronization purposes.
- Throws:
- IOException
 
 - 
syncWithLeaderprotected void syncWithLeader(long newLeaderZxid) throws ExceptionFinally, synchronize our history with the Leader (if Follower) or the LearnerMaster (if Observer).- Parameters:
- newLeaderZxid-
- Throws:
- IOException
- InterruptedException
- Exception
 
 - 
revalidateprotected void revalidate(QuorumPacket qp) throws IOException - Throws:
- IOException
 
 - 
pingprotected void ping(QuorumPacket qp) throws IOException - Throws:
- IOException
 
 - 
shutdownpublic void shutdown() Shutdown the Peer
 
- 
 
-