All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.infinispan.registry.ClusterRegistry Maven / Gradle / Ivy

There is a newer version: 9.1.7.Final
Show newest version
package org.infinispan.registry;

import org.infinispan.factories.annotations.Stop;
import org.infinispan.factories.scopes.Scope;
import org.infinispan.factories.scopes.Scopes;
import org.infinispan.filter.KeyFilter;

import java.util.Set;
import java.util.concurrent.TimeUnit;

/**
 * A registry of scoped key-values available to all the nodes in the cluster.
 * Intended as a general purpose tool for sharing metadata: small amounts of information that is
 * not frequently updated. It is not intended to be used for sharing large amount
 * of information nor to be exposed to users.
 * 

* The registry is a global component, i.e. it is shared by all the caches in the cluster. * In order to avoid collisions each key-value entry is scoped (the scope parameter). * For scoping one can use fully qualified names of the specific classes/packages that make use * of the ClusterRegistry. *

* A reference to the ClusterRegistry can be obtained either through the \@Inject annotation: *

 *    \@Inject
 *    void setup(ClusterRegistry cs) {
 *       ..hold the reference
 *    }
 * 
* or directly form the GlobalComponentRegistry: *
 *    EmbeddedCacheManager:getGlobalComponentRegistry():getGlobalComponent(ClusterRegistry.class)
 * 
* * @author Mircea Markus * @since 6.0 */ @Scope(Scopes.GLOBAL) public interface ClusterRegistry { void put(S scope, K key, V value); void put(S scope, K key, V value, long lifespan, TimeUnit unit); void remove(S scope, K key); V get(S scope, K key); boolean containsKey(S scope, K key); Set keys(S scope); void clear(S scope); void clearAll(); /** * Adds a listener that is notified of changes to keys in a given scope. * * @param scope the scope to watch * @param listener a properly annotated listener instance */ void addListener(S scope, Object listener); /** * Adds a listener that is notified of changes to keys in a given scope and which match a given {@code KeyFilter}. * * @param scope the scope to watch * @param listener a properly annotated listener instance */ void addListener(S scope, KeyFilter keyFilter, Object listener); /** * Detaches a listener instance. * * @param listener the listener to detach */ void removeListener(Object listener); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy