public class StandaloneLeaderElectionService extends Object implements LeaderElectionService
LeaderElectionService
interface. The standalone
implementation assumes that there is only a single LeaderContender
and thus directly
grants him the leadership upon start up. Furthermore, there is no communication needed between
multiple standalone leader election services.Constructor and Description |
---|
StandaloneLeaderElectionService() |
Modifier and Type | Method and Description |
---|---|
void |
confirmLeaderSessionID(UUID leaderSessionID)
Confirms that the new leader session ID has been successfully received by the new leader.
|
boolean |
hasLeadership(UUID leaderSessionId)
Returns true if the
LeaderContender with which the service has been started owns
currently the leadership under the given leader session id. |
void |
start(LeaderContender newContender)
Starts the leader election service.
|
void |
stop()
Stops the leader election service.
|
public void start(LeaderContender newContender) throws Exception
LeaderElectionService
start
in interface LeaderElectionService
newContender
- LeaderContender which applies for the leadershipException
public void stop()
LeaderElectionService
stop
in interface LeaderElectionService
public void confirmLeaderSessionID(UUID leaderSessionID)
LeaderElectionService
LeaderContender
.
The rational behind this method is to establish an order between setting the new leader
session ID in the LeaderContender
and publishing the new leader session ID to the
leader retrieval services.confirmLeaderSessionID
in interface LeaderElectionService
leaderSessionID
- The new leader session IDpublic boolean hasLeadership(@Nonnull UUID leaderSessionId)
LeaderElectionService
LeaderContender
with which the service has been started owns
currently the leadership under the given leader session id.hasLeadership
in interface LeaderElectionService
leaderSessionId
- identifying the current leaderLeaderContender
is the leader, otherwise falseCopyright © 2014–2020 The Apache Software Foundation. All rights reserved.