Package org.infinispan.topology
Interface ClusterTopologyManager
- All Known Implementing Classes:
ClusterTopologyManagerImpl
public interface ClusterTopologyManager
Maintains the topology for all the caches in the cluster.
- Since:
- 5.2
- Author:
- Dan Berindei
-
Nested Class Summary
-
Method Summary
Modifier and TypeMethodDescriptioncurrentJoiners
(String cacheName) Returns the list of nodes that joined the cache with the givencacheName
if the current node is the coordinator.forceAvailabilityMode
(String cacheName, AvailabilityMode availabilityMode) forceRebalance
(String cacheName) getRebalancingStatus
(String cacheName) Retrieves the rebalancing status of a cachehandleJoin
(String cacheName, Address joiner, CacheJoinInfo joinInfo, int viewId) Signals that a new member is joining the cache.handleLeave
(String cacheName, Address leaver, int viewId) Signals that a member is leaving the cache.handleRebalancePhaseConfirm
(String cacheName, Address node, int topologyId, Throwable throwable, int viewId) Marks the rebalance as complete on the sender.handleShutdownRequest
(String cacheName) boolean
boolean
isRebalancingEnabled
(String cacheName) Returns whether rebalancing is enabled or disabled for this container.void
setInitialCacheTopologyId
(String cacheName, int topologyId) Sets the id of the initial topology in given cache.setRebalancingEnabled
(boolean enabled) Globally enables or disables whether automatic rebalancing should occur.setRebalancingEnabled
(String cacheName, boolean enabled) Enables or disables rebalancing for the specified cacheboolean
useCurrentTopologyAsStable
(String cacheName, boolean force)
-
Method Details
-
currentJoiners
Returns the list of nodes that joined the cache with the givencacheName
if the current node is the coordinator. If the node is not the coordinator, the method returns null. -
handleJoin
CompletionStage<CacheStatusResponse> handleJoin(String cacheName, Address joiner, CacheJoinInfo joinInfo, int viewId) throws Exception Signals that a new member is joining the cache. The returnedCacheStatusResponse.cacheTopology
is the current cache topology before the node joined. If the node is the first to join the cache, the returned topology does include the joiner, and it is nevernull
.- Throws:
Exception
-
handleLeave
Signals that a member is leaving the cache.- Throws:
Exception
-
handleRebalancePhaseConfirm
CompletionStage<Void> handleRebalancePhaseConfirm(String cacheName, Address node, int topologyId, Throwable throwable, int viewId) throws Exception Marks the rebalance as complete on the sender.- Throws:
Exception
-
isRebalancingEnabled
boolean isRebalancingEnabled() -
isRebalancingEnabled
Returns whether rebalancing is enabled or disabled for this container. -
setRebalancingEnabled
Globally enables or disables whether automatic rebalancing should occur. -
setRebalancingEnabled
Enables or disables rebalancing for the specified cache -
getRebalancingStatus
Retrieves the rebalancing status of a cache -
forceRebalance
-
forceAvailabilityMode
-
handleShutdownRequest
- Throws:
Exception
-
useCurrentTopologyAsStable
-
setInitialCacheTopologyId
Sets the id of the initial topology in given cache. This is necessary when using entry versions that contain topology id; had we started with topology id 1, newer versions would not be recognized properly. -
getStatus
ClusterTopologyManager.ClusterManagerStatus getStatus()
-