Package org.apache.ignite.cluster
Interface ClusterGroup
- 
- All Known Subinterfaces:
- IgniteCluster
 
 public interface ClusterGroupDefines a cluster group which contains all or a subset of cluster nodes. TheIgniteClusterinterface itself also extendsClusterGroupwhich makes an instance ofIgniteClusterinto a cluster group containing all cluster nodes.ClusteringCluster group allows to group cluster nodes into various subgroups to perform distributed operations on them. All'forXXX(...)'methods will create a child cluster group from the existing cluster group. If you create a new cluster group from the current one, then the resulting cluster group will include a subset of nodes from the current one. The following code shows how to create and nest cluster groups:Ignite ignite = Ignition.ignite(); IgniteCluster cluster = ignite.cluster(); // Cluster group over remote nodes. ClusterGroup remoteNodes = cluster.forRemotes(); // Cluster group over random remote node. ClusterGroup randomNode = remoteNodes.forRandom(); // Cluster group over all nodes with cache named "myCache" enabled. ClusterGroup cacheNodes = cluster.forCacheNodes("myCache"); // Cluster group over all nodes that have the user attribute "group" set to the value "worker". ClusterGroup workerNodes = cluster.forAttribute("group", "worker");
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description ClusterGroupforAttribute(String name, @Nullable Object val)Creates a new cluster group for nodes containing given name and value specified in user attributes.ClusterGroupforCacheNodes(String cacheName)Creates a cluster group for all nodes that have cache with specified name, either in client or server modes.ClusterGroupforClientNodes(String cacheName)Creates a cluster group for all client nodes that access cache with the specified name.ClusterGroupforClients()Creates a cluster group of nodes started in client mode.ClusterGroupforDataNodes(String cacheName)Creates a cluster group for all data nodes that have the cache with the specified name running.ClusterGroupforHost(String host, String... hosts)Gets cluster group consisting from the nodes running on the hosts specified.ClusterGroupforHost(ClusterNode node)Gets cluster group consisting from the nodes in this cluster group residing on the same host as the given node.ClusterGroupforNode(ClusterNode node, ClusterNode... nodes)Creates a cluster group for the given node.ClusterGroupforNodeId(UUID id, UUID... ids)Creates a cluster group for a node with the specified ID.ClusterGroupforNodeIds(Collection<UUID> ids)Creates a cluster group over nodes with specified node IDs.ClusterGroupforNodes(Collection<? extends ClusterNode> nodes)Creates a cluster group over a given set of nodes.ClusterGroupforOldest()Creates a cluster group with one oldest node from the current cluster group.ClusterGroupforOthers(ClusterGroup prj)Creates a cluster group for nodes not included into the given cluster group.ClusterGroupforOthers(ClusterNode node, ClusterNode... nodes)Creates a cluster group for nodes other than the given nodes.ClusterGroupforPredicate(IgnitePredicate<ClusterNode> p)Creates a new cluster group which includes all nodes that pass the given predicate filter.ClusterGroupforRandom()Creates a cluster group with one random node from the current cluster group.ClusterGroupforRemotes()Gets cluster group consisting from the nodes in this cluster group excluding the local node.ClusterGroupforServers()Creates a cluster group of nodes started in server mode.ClusterGroupforYoungest()Creates a cluster group with one youngest node in the current cluster group.Collection<String>hostNames()Gets the read-only collection of hostnames in this cluster group.Igniteignite()Gets instance of grid.ClusterMetricsmetrics()Gets a metrics snapshot for this cluster group.ClusterNodenode()Gets first node from the list of nodes in this cluster group.ClusterNodenode(UUID nid)Gets a node for given ID from this cluster group.Collection<ClusterNode>nodes()Gets the read-only collection of nodes in this cluster group.IgnitePredicate<ClusterNode>predicate()Gets predicate that defines a subset of nodes for this cluster group.
 
- 
- 
- 
Method Detail- 
igniteIgnite ignite() Gets instance of grid.- Returns:
- Grid instance.
 
 - 
forNodesClusterGroup forNodes(Collection<? extends ClusterNode> nodes) Creates a cluster group over a given set of nodes.- Parameters:
- nodes- Collection of nodes to create the cluster group from.
- Returns:
- Cluster group for the provided grid nodes.
 
 - 
forNodeClusterGroup forNode(ClusterNode node, ClusterNode... nodes) Creates a cluster group for the given node.- Parameters:
- node- Node to create cluster group for.
- nodes- Optional additional nodes to include into the cluster group.
- Returns:
- Cluster group for the given nodes.
 
 - 
forOthersClusterGroup forOthers(ClusterNode node, ClusterNode... nodes) Creates a cluster group for nodes other than the given nodes.- Parameters:
- node- Node to exclude from the new cluster group.
- nodes- Optional additional nodes to exclude from the cluster group.
- Returns:
- Cluster group that will contain all nodes from the original cluster group excluding the given nodes.
 
 - 
forOthersClusterGroup forOthers(ClusterGroup prj) Creates a cluster group for nodes not included into the given cluster group.- Parameters:
- prj- Cluster group to exclude from the new cluster group.
- Returns:
- Cluster group for nodes not included into the given cluster group.
 
 - 
forNodeIdsClusterGroup forNodeIds(Collection<UUID> ids) Creates a cluster group over nodes with specified node IDs.- Parameters:
- ids- Collection of node IDs.
- Returns:
- Cluster group over nodes with the specified node IDs.
 
 - 
forNodeIdClusterGroup forNodeId(UUID id, UUID... ids) Creates a cluster group for a node with the specified ID.- Parameters:
- id- Node ID to get the cluster group for.
- ids- Optional additional node IDs to include into the cluster group.
- Returns:
- Cluster group over the node with the specified node IDs.
 
 - 
forPredicateClusterGroup forPredicate(IgnitePredicate<ClusterNode> p) Creates a new cluster group which includes all nodes that pass the given predicate filter.- Parameters:
- p- Predicate filter for nodes to include into the cluster group.
- Returns:
- Cluster group for nodes that passed the predicate filter.
 
 - 
forAttributeClusterGroup forAttribute(String name, @Nullable @Nullable Object val) Creates a new cluster group for nodes containing given name and value specified in user attributes.User attributes for every node are optional and can be specified in grid node configuration. See IgniteConfiguration.getUserAttributes()for more information.- Parameters:
- name- Name of the attribute.
- val- Optional attribute value to match.
- Returns:
- Cluster group for nodes containing specified attribute.
 
 - 
forServersClusterGroup forServers() Creates a cluster group of nodes started in server mode.- Returns:
- Cluster group of nodes started in server mode.
- See Also:
- Ignition.setClientMode(boolean),- IgniteConfiguration.setClientMode(boolean)
 
 - 
forClientsClusterGroup forClients() Creates a cluster group of nodes started in client mode.- Returns:
- Cluster group of nodes started in client mode.
- See Also:
- Ignition.setClientMode(boolean),- IgniteConfiguration.setClientMode(boolean)
 
 - 
forCacheNodesClusterGroup forCacheNodes(String cacheName) Creates a cluster group for all nodes that have cache with specified name, either in client or server modes.- Parameters:
- cacheName- Cache name.
- Returns:
- Cluster group over nodes that have specified cache running.
 
 - 
forDataNodesClusterGroup forDataNodes(String cacheName) Creates a cluster group for all data nodes that have the cache with the specified name running.- Parameters:
- cacheName- Cache name.
- Returns:
- Cluster group over nodes that have the cache with the specified name running.
 
 - 
forClientNodesClusterGroup forClientNodes(String cacheName) Creates a cluster group for all client nodes that access cache with the specified name.- Parameters:
- cacheName- Cache name.
- Returns:
- Cluster group over nodes that have the specified cache running.
 
 - 
forRemotesClusterGroup forRemotes() Gets cluster group consisting from the nodes in this cluster group excluding the local node.- Returns:
- Cluster group consisting from the nodes in this cluster group excluding the local node.
 
 - 
forHostClusterGroup forHost(ClusterNode node) Gets cluster group consisting from the nodes in this cluster group residing on the same host as the given node.- Parameters:
- node- Node to select the host for.
- Returns:
- Cluster group for nodes residing on the same host as the specified node.
 
 - 
forHostClusterGroup forHost(String host, String... hosts) Gets cluster group consisting from the nodes running on the hosts specified.- Parameters:
- host- Host name to get nodes to put in cluster
- hosts- Host names to get nodes to put in cluster.
- Returns:
- Cluster group for nodes residing on the hosts specified.
 
 - 
forRandomClusterGroup forRandom() Creates a cluster group with one random node from the current cluster group.- Returns:
- Cluster group containing one random node from the current cluster group.
 
 - 
forOldestClusterGroup forOldest() Creates a cluster group with one oldest node from the current cluster group. The resulting cluster group is dynamic and will always pick the next oldest node if the previous one leaves topology even after the cluster group has been created.Use node()method to get the oldest node.- Returns:
- Cluster group containing one oldest node from the current cluster group.
 
 - 
forYoungestClusterGroup forYoungest() Creates a cluster group with one youngest node in the current cluster group. The resulting cluster group is dynamic and will always pick the newest node in the topology, even if more nodes entered after the cluster group has been created.- Returns:
- Cluster group containing one youngest node from the current cluster group.
 
 - 
nodesCollection<ClusterNode> nodes() Gets the read-only collection of nodes in this cluster group.- Returns:
- All nodes in this cluster group.
 
 - 
nodeClusterNode node(UUID nid) Gets a node for given ID from this cluster group.- Parameters:
- nid- Node ID.
- Returns:
- Node with given ID from this cluster group or null, if such node does not exist.
 
 - 
nodeClusterNode node() Gets first node from the list of nodes in this cluster group. This method is specifically useful for cluster groups with one node only.- Returns:
- First node from the list of nodes in this cluster group or nullif the cluster group is empty.
 
 - 
hostNamesCollection<String> hostNames() Gets the read-only collection of hostnames in this cluster group.- Returns:
- All hostnames in this cluster group.
 
 - 
predicateIgnitePredicate<ClusterNode> predicate() Gets predicate that defines a subset of nodes for this cluster group.- Returns:
- Predicate that defines a subset of nodes for this cluster group.
 
 - 
metricsClusterMetrics metrics() throws IgniteException Gets a metrics snapshot for this cluster group.- Returns:
- Metrics snapshot.
- Throws:
- IgniteException- If this cluster group is empty.
 
 
- 
 
-