| 
 | ehcache | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectnet.sf.ehcache.distribution.RMISynchronousCacheReplicator
public class RMISynchronousCacheReplicator
Listens to CacheManager and Cache events and propagates those to
 CachePeer peers of the Cache.
| Field Summary | |
|---|---|
| protected  boolean | replicatePutsWhether to replicate puts. | 
| protected  boolean | replicateRemovalsWhether to replicate removes | 
| protected  boolean | replicateUpdatesWhether to replicate updates. | 
| protected  boolean | replicateUpdatesViaCopyWhether an update (a put) should be by copy or by invalidation, (a remove). | 
| protected  Status | statusThe status of the replicator. | 
| Constructor Summary | |
|---|---|
| RMISynchronousCacheReplicator(boolean replicatePuts,
                              boolean replicateUpdates,
                              boolean replicateUpdatesViaCopy,
                              boolean replicateRemovals)Constructor for internal and subclass use | |
| Method Summary | |
|---|---|
|  boolean | alive()Checks that the replicator is is STATUS_ALIVE. | 
|  java.lang.Object | clone()Creates a clone of this listener. | 
|  void | dispose()Give the replicator a chance to cleanup and free resources when no longer needed | 
|  boolean | isReplicateUpdatesViaCopy()Returns whether update is through copy or invalidate | 
| (package private) static java.util.List | listRemoteCachePeers(Ehcache cache)Package protected List of cache peers | 
|  boolean | notAlive()Asserts that the replicator is active. | 
|  void | notifyElementEvicted(Ehcache cache,
                     Element element)Called immediately after an element is evicted from the cache. | 
|  void | notifyElementExpired(Ehcache cache,
                     Element element)Called immediately after an element is found to be expired. This implementation does not propagate expiries. | 
|  void | notifyElementPut(Ehcache cache,
                 Element element)Called immediately after an element has been put into the cache. | 
|  void | notifyElementRemoved(Ehcache cache,
                     Element element)Called immediately after an attempt to remove an element. | 
|  void | notifyElementUpdated(Ehcache cache,
                     Element element)Called immediately after an element has been put into the cache and the element already existed in the cache. | 
|  void | notifyRemoveAll(Ehcache cache)Called during Ehcache.removeAll()to indicate that the all
 elements have been removed from the cache in a bulk operation. | 
| Methods inherited from class java.lang.Object | 
|---|
| equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Field Detail | 
|---|
protected Status status
STATUS_ALIVE
protected final boolean replicatePuts
protected final boolean replicateUpdates
protected final boolean replicateUpdatesViaCopy
#replicateUpdates is true.
protected final boolean replicateRemovals
| Constructor Detail | 
|---|
public RMISynchronousCacheReplicator(boolean replicatePuts,
                                     boolean replicateUpdates,
                                     boolean replicateUpdatesViaCopy,
                                     boolean replicateRemovals)
replicatePuts - replicateUpdates - replicateUpdatesViaCopy - replicateRemovals - | Method Detail | 
|---|
public void notifyElementPut(Ehcache cache,
                             Element element)
                      throws CacheException
Cache.put(net.sf.ehcache.Element) method
 will block until this method returns.
 
 Implementers may wish to have access to the Element's fields, including value, so the element is provided.
 Implementers should be careful not to modify the element. The effect of any modifications is undefined.
notifyElementPut in interface CacheEventListenercache - the cache emitting the notificationelement - the element which was just put into the cache.
CacheException
public void notifyElementUpdated(Ehcache cache,
                                 Element element)
                          throws CacheException
Cache.put(net.sf.ehcache.Element) method
 will block until this method returns.
 
 Implementers may wish to have access to the Element's fields, including value, so the element is provided.
 Implementers should be careful not to modify the element. The effect of any modifications is undefined.
notifyElementUpdated in interface CacheEventListenercache - the cache emitting the notificationelement - the element which was just put into the cache.
CacheException
public void notifyElementRemoved(Ehcache cache,
                                 Element element)
                          throws CacheException
notifyElementRemoved in interface CacheEventListenercache - the cache emitting the notificationelement - the element just deleted, or a synthetic element with just the key set if
                no element was removed.param element just deleted
CacheException
public final void notifyElementExpired(Ehcache cache,
                                       Element element)
Cache.remove(Object) method will block until this method returns.
 
 As the Element has been expired, only what was the key of the element is known.
 
 Elements are checked for expiry in ehcache at the following times:
 Cache.DEFAULT_EXPIRY_THREAD_INTERVAL_SECONDS
 
notifyElementExpired in interface CacheEventListenercache - the cache emitting the notificationelement - the element that has just expired
                
                Deadlock Warning: expiry will often come from the DiskStore
                expiry thread. It holds a lock to the DiskStorea the time the
                notification is sent. If the implementation of this method calls into a
                synchronized Cache method and that subsequently calls into
                DiskStore a deadlock will result. Accordingly implementers of this method
                should not call back into Cache.
public void notifyElementEvicted(Ehcache cache,
                                 Element element)
notifyElementEvicted in interface CacheEventListenercache - the cache emitting the notificationelement - the element that has just been evictedpublic void notifyRemoveAll(Ehcache cache)
Ehcache.removeAll() to indicate that the all
 elements have been removed from the cache in a bulk operation. The usual
 notifyElementRemoved(net.sf.ehcache.Ehcache,net.sf.ehcache.Element)
 is not called.
 
 This notification exists because clearing a cache is a special case. It is often
 not practical to serially process notifications where potentially millions of elements
 have been bulk deleted.
notifyRemoveAll in interface CacheEventListenercache - the cache emitting the notificationstatic java.util.List listRemoteCachePeers(Ehcache cache)
cache - 
CachePeer peers for the given cache, excluding the local peer.public final boolean isReplicateUpdatesViaCopy()
CacheReplicator
isReplicateUpdatesViaCopy in interface CacheReplicatorpublic final boolean notAlive()
notAlive in interface CacheReplicatorpublic final boolean alive()
STATUS_ALIVE.
alive in interface CacheReplicatorSTATUS_ALIVE, else false.public void dispose()
dispose in interface CacheEventListener
public java.lang.Object clone()
                       throws java.lang.CloneNotSupportedException
clone in interface CacheEventListenerclone in class java.lang.Objectjava.lang.CloneNotSupportedException - if the listener could not be cloned.| 
 | ehcache | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||