Package org.infinispan.affinity
Interface KeyAffinityService<K>
- All Superinterfaces:
- Lifecycle
- All Known Implementing Classes:
- KeyAffinityServiceImpl
Defines a service that generates keys to be mapped to specific nodes in a distributed(vs. replicated) cluster.
 The service is instantiated through through one of the factory methods from 
KeyAffinityServiceFactory.
 
 Sample usage:
 
 
    Cache<String, Long> cache = getDistributedCache();
    KeyAffinityService<String> service = KeyAffinityServiceFactory.newKeyAffinityService(cache, 100);
    ...
    String sessionId = sessionObject.getId();
    String newCollocatedSession = service.getCollocatedKey(sessionId);
    //this will reside on the same node in the cluster
    cache.put(newCollocatedSession, someInfo);
 KeyGenerator for obtaining and distributing the generated keys. If key uniqueness is
 needed that should be enforced in the generator.
 
 The service might also drop key generated through the KeyGenerator.- Since:
- 4.1
- Author:
- Mircea.Markus@jboss.com
- See Also:
- 
Method SummaryModifier and TypeMethodDescriptiongetCollocatedKey(K otherKey) Returns a key that will be distributed on the same node as the supplied key.getKeyForAddress(Address address) Returns a key that will be distributed on the cluster node identified by address.booleanChecks weather or not the service is started.
- 
Method Details- 
getKeyForAddressReturns a key that will be distributed on the cluster node identified by address.- Parameters:
- address- identifying the cluster node.
- Returns:
- a key object
- Throws:
- IllegalStateException- if the service has not been started or it is shutdown
 
- 
getCollocatedKeyReturns a key that will be distributed on the same node as the supplied key.- Parameters:
- otherKey- the key for which we need a collocation
- Returns:
- a key object
- Throws:
- IllegalStateException- if the service has not been started or it is shutdown
 
- 
isStartedboolean isStarted()Checks weather or not the service is started.
 
-