public class NonstopAwareNaturalIdRegionAccessStrategy extends Object implements NaturalIdRegionAccessStrategy
NaturalIdRegionAccessStrategy
that handles NonStopCacheException
using
HibernateNonstopCacheExceptionHandler
Constructor and Description |
---|
NonstopAwareNaturalIdRegionAccessStrategy(NaturalIdRegionAccessStrategy actualStrategy,
HibernateNonstopCacheExceptionHandler hibernateNonstopExceptionHandler)
Constructor accepting the actual
NaturalIdRegionAccessStrategy and the HibernateNonstopCacheExceptionHandler |
Modifier and Type | Method and Description |
---|---|
boolean |
afterInsert(Object key,
Object value)
Called after an item has been inserted (after the transaction completes),
instead of calling release().
|
boolean |
afterUpdate(Object key,
Object value,
SoftLock lock)
Called after an item has been updated (after the transaction completes),
instead of calling release().
|
void |
evict(Object key)
Forcibly evict an item from the cache immediately without regard for transaction
isolation.
|
void |
evictAll()
Forcibly evict all items from the cache immediately without regard for transaction
isolation.
|
Object |
get(Object key,
long txTimestamp)
Attempt to retrieve an object from the cache.
|
NaturalIdRegion |
getRegion()
Get the wrapped naturalId cache region
|
boolean |
insert(Object key,
Object value)
Called after an item has been inserted (before the transaction completes),
instead of calling evict().
|
SoftLock |
lockItem(Object key,
Object version)
We are going to attempt to update/delete the keyed object.
|
SoftLock |
lockRegion()
Lock the entire region
|
boolean |
putFromLoad(Object key,
Object value,
long txTimestamp,
Object version)
Attempt to cache an object, after loading from the database.
|
boolean |
putFromLoad(Object key,
Object value,
long txTimestamp,
Object version,
boolean minimalPutOverride)
Attempt to cache an object, after loading from the database, explicitly
specifying the minimalPut behavior.
|
void |
remove(Object key)
Called after an item has become stale (before the transaction completes).
|
void |
removeAll()
Called to evict data from the entire region
|
void |
unlockItem(Object key,
SoftLock lock)
Called when we have finished the attempted update/delete (which may or
may not have been successful), after transaction completion.
|
void |
unlockRegion(SoftLock lock)
Called after we have finished the attempted invalidation of the entire
region
|
boolean |
update(Object key,
Object value)
Called after an item has been updated (before the transaction completes),
instead of calling evict().
|
public NonstopAwareNaturalIdRegionAccessStrategy(NaturalIdRegionAccessStrategy actualStrategy, HibernateNonstopCacheExceptionHandler hibernateNonstopExceptionHandler)
NaturalIdRegionAccessStrategy
and the HibernateNonstopCacheExceptionHandler
actualStrategy
- The wrapped NaturalIdRegionAccessStrategyhibernateNonstopExceptionHandler
- The exception handlerpublic boolean insert(Object key, Object value) throws CacheException
NaturalIdRegionAccessStrategy
insert
in interface NaturalIdRegionAccessStrategy
key
- The item keyvalue
- The itemCacheException
- Propogated from underlying Region
public boolean afterInsert(Object key, Object value) throws CacheException
NaturalIdRegionAccessStrategy
afterInsert
in interface NaturalIdRegionAccessStrategy
key
- The item keyvalue
- The itemCacheException
- Propogated from underlying Region
public boolean update(Object key, Object value) throws CacheException
NaturalIdRegionAccessStrategy
update
in interface NaturalIdRegionAccessStrategy
key
- The item keyvalue
- The itemCacheException
- Propogated from underlying Region
public boolean afterUpdate(Object key, Object value, SoftLock lock) throws CacheException
NaturalIdRegionAccessStrategy
afterUpdate
in interface NaturalIdRegionAccessStrategy
key
- The item keyvalue
- The itemlock
- The lock previously obtained from RegionAccessStrategy.lockItem(java.lang.Object, java.lang.Object)
CacheException
- Propogated from underlying Region
public NaturalIdRegion getRegion()
NaturalIdRegionAccessStrategy
getRegion
in interface NaturalIdRegionAccessStrategy
public void evict(Object key) throws CacheException
RegionAccessStrategy
evict
in interface RegionAccessStrategy
key
- The key of the item to removeCacheException
- Propogated from underlying Region
public void evictAll() throws CacheException
RegionAccessStrategy
evictAll
in interface RegionAccessStrategy
CacheException
- Propogated from underlying Region
public Object get(Object key, long txTimestamp) throws CacheException
RegionAccessStrategy
get
in interface RegionAccessStrategy
key
- The key of the item to be retrieved.txTimestamp
- a timestamp prior to the transaction start timeCacheException
- Propogated from underlying Region
public SoftLock lockItem(Object key, Object version) throws CacheException
RegionAccessStrategy
RegionAccessStrategy.unlockItem(java.lang.Object, org.hibernate.cache.spi.access.SoftLock)
, to release the
lock. Concurrency strategies which do not support client-visible
locks may silently return null.lockItem
in interface RegionAccessStrategy
key
- The key of the item to lockversion
- The item's current version valueCacheException
- Propogated from underlying Region
public SoftLock lockRegion() throws CacheException
RegionAccessStrategy
lockRegion
in interface RegionAccessStrategy
CacheException
- Propogated from underlying Region
public boolean putFromLoad(Object key, Object value, long txTimestamp, Object version, boolean minimalPutOverride) throws CacheException
RegionAccessStrategy
putFromLoad
in interface RegionAccessStrategy
key
- The item keyvalue
- The itemtxTimestamp
- a timestamp prior to the transaction start timeversion
- the item version numberminimalPutOverride
- Explicit minimalPut flagCacheException
- Propogated from underlying Region
public boolean putFromLoad(Object key, Object value, long txTimestamp, Object version) throws CacheException
RegionAccessStrategy
putFromLoad
in interface RegionAccessStrategy
key
- The item keyvalue
- The itemtxTimestamp
- a timestamp prior to the transaction start timeversion
- the item version numberCacheException
- Propogated from underlying Region
public void remove(Object key) throws CacheException
RegionAccessStrategy
remove
in interface RegionAccessStrategy
key
- The key of the item to removeCacheException
- Propogated from underlying Region
public void removeAll() throws CacheException
RegionAccessStrategy
removeAll
in interface RegionAccessStrategy
CacheException
- Propogated from underlying Region
public void unlockItem(Object key, SoftLock lock) throws CacheException
RegionAccessStrategy
unlockItem
in interface RegionAccessStrategy
key
- The item keylock
- The lock previously obtained from RegionAccessStrategy.lockItem(java.lang.Object, java.lang.Object)
CacheException
- Propogated from underlying Region
public void unlockRegion(SoftLock lock) throws CacheException
RegionAccessStrategy
unlockRegion
in interface RegionAccessStrategy
lock
- The lock previously obtained from RegionAccessStrategy.lockRegion()
CacheException
- Propogated from underlying Region
Copyright © 2001-2015 Red Hat, Inc. All Rights Reserved.