此内容没有您所选择的语言版本。
7.5. Clustered Listeners
			Clustered listeners allow listeners to be used in a distributed cache configuration. In a distributed cache environment, registered local listeners are only notified of events that are local to the node where the event has occurred. Clustered listeners resolve this issue by allowing a single listener to receive any write notification that occurs in the cluster, regardless of where the event occurred. As a result, clustered listeners perform slower than non-clustered listeners, which only provide event notifications for the node on which the event occurs.
		
			When using clustered listeners, client applications are notified when an entry is added, updated, expired, or deleted in a particular cache. The event is cluster-wide so that client applications can access the event regardless of the node on which the application resides or connects with.
		
			The event will always be triggered on the node where the listener was registered, while disregarding where the cache update originated.
		
			23155%2C+Developer+Guide-6.630-06-2017+15%3A00%3A55JBoss+Data+Grid+6Documentation6.6.1Report a bug
		
7.5.1. Configuring Clustered Listeners
复制链接链接已复制到粘贴板!
		In the following use case, listener stores events as it receives them.
	
Procedure 7.1. Clustered Listener Configuration
- Clustered listeners are enabled by annotating the@Listenerclass withclustered=true.
- The following methods are annotated to allow client applications to be notified when entries are added, modified, expired, or removed.- @CacheEntryCreated
- @CacheEntryModified
- @CacheEntryExpired
- @CacheEntryRemoved
 
- The listener is registered with a cache, with the option of passing on a filter or converter.
		The following limitations occur when using clustered listeners, that do not apply to non-clustered listeners:
	
- A cluster listener can only listen to entries that are created, modified, expired, or removed. No other events are listened to by a clustered listener.
- Only post events are sent to a clustered listener, pre events are ignored.
7.5.2. The Cache Listener API
复制链接链接已复制到粘贴板!
		Clustered listeners can be added on top of the existing 
@CacheListener API via the addListener method.
	Example 7.3. The Cache Listener API
- The Cache API
- The local or clustered listener can be registered with thecache.addListenermethod, and is active until one of the following events occur.- The listener is explicitly unregistered by invokingcache.removeListener.
- The node on which the listener was registered crashes.
 
- Listener Annotation
- The listener annotation is enhanced with two attributes:- clustered():This attribute defines whether the annotated listener is clustered or not. Note that clustered listeners can only be notified for- @CacheEntryRemoved,- @CacheEntryCreated,- @CacheEntryExpired, and- @CacheEntryModifiedevents. This attribute is false by default.
- includeCurrentState(): This attribute applies to clustered listeners only, and is false by default. When set to- true, the entire existing state within the cluster is evaluated. When being registered, a listener will immediately be sent a- CacheCreatedEventfor every entry in the cache.
 
- oldValueand- oldMetadata
- TheoldValueandoldMetadatavalues are extra methods on the accept method ofCacheEventFilterandCacheEventConverterclasses. They values are provided to any listener, including local listeners. For more information about these values, see the JBoss Data Grid API Documentation.
- EventType
- TheEventTypeincludes the type of event, whether it was a retry, and if it was a pre or post event.
		When using clustered listeners, the order in which the cache is updated is reflected in the sequence of notifications received.
	
		The clustered listener does not guarantee that an event is sent only once. The listener implementation must be idempotent in order to prevent situations where the same event is sent more than once. Implementors can expect singularity to be honored for stable clusters and outside of the time span in which synthetic events are generated as a result of 
includeCurrentState.
	7.5.3. Clustered Listener Example
复制链接链接已复制到粘贴板!
		The following use case demonstrates a listener that wants to know when orders are generated that have a destination of New York, NY. The listener requires a Filter that filters all orders that come in and out of New York. The listener also requires a Converter as it does not require the entire order, only the date it is to be delivered.
	
Example 7.4. Use Case: Filtering and Converting the New York orders
7.5.4. Optimized Cache Filter Converter
复制链接链接已复制到粘贴板!
		The example provided in Section 7.5.3, “Clustered Listener Example” could use the optimized 
CacheEventFilterConverter, in order to perform the filtering and converting of results into one step.
	
		The 
CacheEventFilterConverter is an optimization that allows the event filter and conversion to be performed in one step. This can be used when an event filter and converter are most efficiently used as the same object, composing the filtering and conversion in the same method. This can only be used in situations where your conversion will not return a null value, as a returned value of null indicates that the value did not pass the filter. To convert a null value, use the CacheEventFilter and the CacheEventConverter interfaces independently.
	
		The following is an example of the New York orders use case using the 
CacheEventFilterConverter:
	Example 7.5. CacheEventFilterConverter
			When registering the listener, provide the 
FilterConverter as both arguments to the filter and converter:
		OrderDateFilterConverter filterConverter = new OrderDateFilterConverter("NY", "New York");
cache.addListener(listener, filterConveter, filterConverter);
OrderDateFilterConverter filterConverter = new OrderDateFilterConverter("NY", "New York");
cache.addListener(listener, filterConveter, filterConverter);