VMware GemFire Java API Reference
Interface Cache
- 
- All Superinterfaces:
- java.lang.AutoCloseable,- GemFireCache,- RegionService
 
 public interface Cache extends GemFireCache Caches are obtained from theCacheFactory.create()method. SeeCacheFactoryfor common usage patterns for creating the cache instance.When a cache is created a DistributedSystemis also created. This system tells the cache where to find other caches on the network and how to communicate with them. The system can also specify a "cache-xml-file" property which will cause this cache to be initialized with the contents of that file. The contents must comply with the"doc-files/cache8_0.dtd"file and the top level element must be acacheelement.When a cache will no longer be used it should be closed. Once itis closedany attempt to use it or anyRegionobtained from it will cause aCacheClosedExceptionto be thrown.A cache can have multiple root regions, each with a different name. - Since:
- GemFire 2.0
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Default Methods Deprecated Methods Modifier and Type Method Description CacheServeraddCacheServer()Creates a new cache server, with the default configuration, that will allow clients to access this cache.voidclose(boolean keepAlive)Deprecated.as of 6.5 useClientCache.close(boolean)instead.AsyncEventQueueFactorycreateAsyncEventQueueFactory()CreatesAsyncEventQueueFactoryfor creating a AsyncEventQueueGatewayReceiverFactorycreateGatewayReceiverFactory()CreatesGatewayReceiverFactoryfor creating a GatewayReceiverGatewaySenderFactorycreateGatewaySenderFactory()CreatesGatewaySenderFactoryfor creating a SerialGatewaySender<K,V>
 Region<K,V>createRegion(java.lang.String name, RegionAttributes<K,V> aRegionAttributes)Deprecated.as of 6.5 usecreateRegionFactory(RegionAttributes)instead<K,V>
 RegionFactory<K,V>createRegionFactory()Creates aRegionFactorywhich can be used to specify additional attributes forRegioncreation.<K,V>
 RegionFactory<K,V>createRegionFactory(java.lang.String regionAttributesId)Creates aRegionFactoryfor creating aRegionfromRegionAttributesmapped to this regionAttributesId<K,V>
 RegionFactory<K,V>createRegionFactory(RegionAttributes<K,V> regionAttributes)Creates aRegionFactoryfor creating aRegionfrom the given regionAttributes<K,V>
 RegionFactory<K,V>createRegionFactory(RegionShortcut shortcut)<K,V>
 Region<K,V>createVMRegion(java.lang.String name, RegionAttributes<K,V> aRegionAttributes)Deprecated.as of GemFire 5.0, usecreateRegion(java.lang.String, org.apache.geode.cache.RegionAttributes<K, V>)instead.default java.util.Set<DistributedMember>getAdminMembers()Deprecated.as of 10.1 use themanagementpackage insteadAsyncEventQueuegetAsyncEventQueue(java.lang.String id)Returns theAsyncEventQueuewith the given id added to this Cache.java.util.Set<AsyncEventQueue>getAsyncEventQueues()Returns allAsyncEventQueues for this Cachejava.util.List<CacheServer>getCacheServers()Returns a collection of all of theCacheServers that can serve the contents of thisCacheto clients.GatewayConflictResolvergetGatewayConflictResolver()Returns the current gateway event conflict resolverjava.util.Set<GatewayReceiver>getGatewayReceivers()Returns allGatewayReceivers for this CacheGatewaySendergetGatewaySender(java.lang.String id)Returns theGatewaySenderwith the given id added to this Cache.java.util.Set<GatewaySender>getGatewaySenders()Returns allGatewaySenders for this Cache.intgetLockLease()Gets the length, in seconds, of distributed lock leases obtained by this cache.intgetLockTimeout()Gets the number of seconds a cache operation will wait to obtain a distributed lock lease.LogWriterI18ngetLoggerI18n()Deprecated.as of 6.5 use getLogger().convertToLogWriterI18n() insteadjava.util.Set<DistributedMember>getMembers()Returns a set of the other non-administrative members in the distributed system.java.util.Set<DistributedMember>getMembers(Region region)Returns a set of the members in the distributed system that have the given region.intgetMessageSyncInterval()Gets the frequency (in seconds) at which a message will be sent by the primary cache-server to all the secondary cache-server nodes to remove the events which have already been dispatched from the queue.CachegetReconnectedCache()Returns the new Cache if there was an auto-reconnect and the cache was recreated.intgetSearchTimeout()Gets the number of seconds a cachegetoperation can spend searching for a value before it times out.LogWriterI18ngetSecurityLoggerI18n()Deprecated.as of 6.5 use getSecurityLogger().convertToLogWriterI18n() insteadCacheSnapshotServicegetSnapshotService()Obtains the snapshot service to allow the cache data to be imported or exported.booleanisReconnecting()Test to see whether the Cache is in the process of reconnecting and recreating a new cache after it has been removed from the system by other members or has shut down due to missing Roles and is reconnecting.booleanisServer()Returns whether or not this cache resides in a "cache server" VM.voidreadyForEvents()Deprecated.as of 6.5 useClientCache.readyForEvents()instead.voidsetGatewayConflictResolver(GatewayConflictResolver resolver)Adds a gateway event conflict resolution resolver.voidsetIsServer(boolean isServer)Sets whether or not thisCacheresides in a long-running "cache server" VM.voidsetLockLease(int seconds)Sets the length, in seconds, of distributed lock leases obtained by this cache.voidsetLockTimeout(int seconds)Sets the number of seconds a cache operation may wait to obtain a distributed lock lease before timing out.voidsetMessageSyncInterval(int seconds)Sets the frequency (in seconds) at which a message will be sent by the primary cache-server node to all the secondary cache-server nodes to remove the events which have already been dispatched from the queue.voidsetSearchTimeout(int seconds)Sets the number of seconds a cache get operation can spend searching for a value.voidstopReconnecting()Force the Cache to stop reconnecting.booleanwaitUntilReconnected(long time, java.util.concurrent.TimeUnit units)Wait for the Cache to finish reconnecting to the distributed system and recreate a new Cache.- 
Methods inherited from interface org.apache.geode.cache.GemFireCachecreateDiskStoreFactory, findDiskStore, getCacheTransactionManager, getCopyOnRead, getDistributedSystem, getInitializer, getInitializerProps, getJNDIContext, getLogger, getName, getPdxDiskStore, getPdxIgnoreUnreadFields, getPdxPersistent, getPdxReadSerialized, getPdxSerializer, getRegionAttributes, getResourceManager, getSecurityLogger, listRegionAttributes, loadCacheXml, registerPdxMetaData, setCopyOnRead, setRegionAttributes
 - 
Methods inherited from interface org.apache.geode.cache.RegionServiceclose, createPdxEnum, createPdxInstanceFactory, getCancelCriterion, getJsonDocumentFactory, getJsonDocumentFactory, getJsonFormatter, getQueryService, getRegion, isClosed, rootRegions
 
- 
 
- 
- 
- 
Method Detail- 
close@Deprecated void close(boolean keepAlive) Deprecated.as of 6.5 useClientCache.close(boolean)instead.Terminates this object cache and releases all the resources. CallsRegion.close()on each region in the cache. After this cache is closed, any further method call on this cache or any region object will throwCacheClosedException, unless otherwise noted.- Parameters:
- keepAlive- whether the server should keep the durable client's queues alive for the timeout period
- Throws:
- CacheClosedException- if the cache is already closed.
 
 - 
createVMRegion@Deprecated <K,V> Region<K,V> createVMRegion(java.lang.String name, RegionAttributes<K,V> aRegionAttributes) throws RegionExistsException, TimeoutException Deprecated.as of GemFire 5.0, usecreateRegion(java.lang.String, org.apache.geode.cache.RegionAttributes<K, V>)instead.Creates a VM region using the specified RegionAttributes.- Type Parameters:
- K- the type of keys in the region
- V- the type of values in the region
- Parameters:
- name- the name of the region to create
- aRegionAttributes- the attributes of the root region
- Returns:
- the region object
- Throws:
- RegionExistsException- if a region is already in this cache
- LeaseExpiredException- if lease expired on distributed lock for Scope.GLOBAL
- TimeoutException- if timed out getting distributed lock for Scope.GLOBAL
- CacheClosedException- if the cache is closed
- java.lang.IllegalStateException- If the supplied RegionAttributes violate the region creation constraints with a region of the same name in another cache in the distributed system
 
 - 
createRegion@Deprecated <K,V> Region<K,V> createRegion(java.lang.String name, RegionAttributes<K,V> aRegionAttributes) throws RegionExistsException, TimeoutException Deprecated.as of 6.5 usecreateRegionFactory(RegionAttributes)insteadCreates a region using the specified RegionAttributes.- Type Parameters:
- K- the type of keys in the region
- V- the type of values in the region
- Parameters:
- name- the name of the region to create
- aRegionAttributes- the attributes of the root region
- Returns:
- the region object
- Throws:
- RegionExistsException- if a region is already in this cache
- LeaseExpiredException- if lease expired on distributed lock for Scope.GLOBAL
- TimeoutException- if timed out getting distributed lock for Scope.GLOBAL
- CacheClosedException- if the cache is closed
- java.lang.IllegalStateException- If the supplied RegionAttributes violate the region creation constraints with a region of the same name in another cache in the distributed system
- Since:
- GemFire 5.0
 
 - 
createRegionFactory<K,V> RegionFactory<K,V> createRegionFactory() Creates aRegionFactorywhich can be used to specify additional attributes forRegioncreation.- Type Parameters:
- K- the type of keys in the region
- V- the type of values in the region
- Returns:
- a RegionFactorywhich can be used to specify additional attributes forRegioncreation
- Since:
- GemFire 6.5
- See Also:
- createRegionFactory(RegionShortcut)
 
 - 
createRegionFactory<K,V> RegionFactory<K,V> createRegionFactory(RegionShortcut shortcut) - Type Parameters:
- K- the type of keys in the region
- V- the type of values in the region
- Parameters:
- shortcut- the region type as defined by- RegionShortcut
- Returns:
- a RegionFactory
- Since:
- GemFire 6.5
 
 - 
createRegionFactory<K,V> RegionFactory<K,V> createRegionFactory(java.lang.String regionAttributesId) Creates aRegionFactoryfor creating aRegionfromRegionAttributesmapped to this regionAttributesId- Type Parameters:
- K- the type of keys in the region
- V- the type of values in the region
- Parameters:
- regionAttributesId- the Id of RegionAttributes to be used
- Returns:
- a RegionFactory
- Since:
- GemFire 6.5
- See Also:
- GemFireCache.setRegionAttributes(String, RegionAttributes)
 
 - 
createRegionFactory<K,V> RegionFactory<K,V> createRegionFactory(RegionAttributes<K,V> regionAttributes) Creates aRegionFactoryfor creating aRegionfrom the given regionAttributes- Type Parameters:
- K- the type of keys in the region
- V- the type of values in the region
- Parameters:
- regionAttributes- regionAttributes for the new region
- Returns:
- a RegionFactory
- Since:
- GemFire 6.5
- See Also:
- createRegionFactory(RegionShortcut)
 
 - 
getLoggerI18n@Deprecated LogWriterI18n getLoggerI18n() Deprecated.as of 6.5 use getLogger().convertToLogWriterI18n() insteadInternal GemStone method for accessing the internationalized logging object for GemFire, useGemFireCache.getLogger()instead. This method does not throwCacheClosedExceptionif the cache is closed.- Returns:
- the logging object
 
 - 
getSecurityLoggerI18n@Deprecated LogWriterI18n getSecurityLoggerI18n() Deprecated.as of 6.5 use getSecurityLogger().convertToLogWriterI18n() insteadInternal GemStone method for accessing the internationalized logging object for GemFire, useGemFireCache.getSecurityLogger()instead. This method does not throwCacheClosedExceptionif the cache is closed.- Returns:
- the security logging object
 
 - 
getLockTimeoutint getLockTimeout() Gets the number of seconds a cache operation will wait to obtain a distributed lock lease. This method does not throwCacheClosedExceptionif the cache is closed.- Returns:
- the number of seconds a cache operation will wait to obtain a distributed lock lease
 
 - 
setLockTimeoutvoid setLockTimeout(int seconds) Sets the number of seconds a cache operation may wait to obtain a distributed lock lease before timing out.- Parameters:
- seconds- the number of seconds a cache operation may wait to obtain a distributed lock lease before timing out
- Throws:
- java.lang.IllegalArgumentException- if- secondsis less than zero
 
 - 
getMessageSyncIntervalint getMessageSyncInterval() Gets the frequency (in seconds) at which a message will be sent by the primary cache-server to all the secondary cache-server nodes to remove the events which have already been dispatched from the queue.- Returns:
- The time interval in seconds
 
 - 
setMessageSyncIntervalvoid setMessageSyncInterval(int seconds) Sets the frequency (in seconds) at which a message will be sent by the primary cache-server node to all the secondary cache-server nodes to remove the events which have already been dispatched from the queue.- Parameters:
- seconds- the time interval in seconds
- Throws:
- java.lang.IllegalArgumentException- if- secondsis less than zero
 
 - 
getLockLeaseint getLockLease() Gets the length, in seconds, of distributed lock leases obtained by this cache. This method does not throwCacheClosedExceptionif the cache is closed.- Returns:
- the length, in seconds, of distributed lock leases obtained by this cache
 
 - 
setLockLeasevoid setLockLease(int seconds) Sets the length, in seconds, of distributed lock leases obtained by this cache.- Parameters:
- seconds- the length, in seconds, of distributed lock leases obtained by this cache
- Throws:
- java.lang.IllegalArgumentException- if- secondsis less than zero.
 
 - 
getSearchTimeoutint getSearchTimeout() Gets the number of seconds a cachegetoperation can spend searching for a value before it times out. The search includes any time spent loading the object. When the search times out it causes the get to fail by throwing an exception. This method does not throwCacheClosedExceptionif the cache is closed.- Returns:
- the number of seconds a cache getoperation can spend searching for a value before it times out
 
 - 
setSearchTimeoutvoid setSearchTimeout(int seconds) Sets the number of seconds a cache get operation can spend searching for a value.- Parameters:
- seconds- the number of seconds a cache get operation can spend searching for a value
- Throws:
- java.lang.IllegalArgumentException- if- secondsis less than zero
 
 - 
addCacheServerCacheServer addCacheServer() Creates a new cache server, with the default configuration, that will allow clients to access this cache.For the default configuration see the constants in CacheServer.- Returns:
- the newly created CacheServer
- Since:
- GemFire 5.7
- See Also:
- CacheServer
 
 - 
getCacheServersjava.util.List<CacheServer> getCacheServers() Returns a collection of all of theCacheServers that can serve the contents of thisCacheto clients.- Returns:
- a collection of all of the CacheServers
- Since:
- GemFire 5.7
- See Also:
- addCacheServer()
 
 - 
setGatewayConflictResolvervoid setGatewayConflictResolver(GatewayConflictResolver resolver) Adds a gateway event conflict resolution resolver. This is invoked if an event is processed that comes from a different distributed system than the last event to modify the affected entry. It may alter the event or disallow the event. If it does neither the event is applied to the cache if its timestamp is newer than what is in the cache or if it is the same and the event's distributed system ID is larger than that of the last event to modify the affected entry.- Parameters:
- resolver- gateway event conflict resolution resolver
- Since:
- GemFire 7.0
 
 - 
getGatewayConflictResolverGatewayConflictResolver getGatewayConflictResolver() Returns the current gateway event conflict resolver- Returns:
- the current gateway event conflict resolver
- Since:
- GemFire 7.0
 
 - 
setIsServervoid setIsServer(boolean isServer) Sets whether or not thisCacheresides in a long-running "cache server" VM. A cache server may be an application VM or may be a stand-along VM.- Parameters:
- isServer- whether this- Cacheresides in a long-running "cache server" VM
- Since:
- GemFire 4.0
 
 - 
isServerboolean isServer() Returns whether or not this cache resides in a "cache server" VM.- Returns:
- whether this cache resides in a "cache server" VM
- Since:
- GemFire 4.0
- See Also:
- setIsServer(boolean)
 
 - 
readyForEvents@Deprecated void readyForEvents() Deprecated.as of 6.5 useClientCache.readyForEvents()instead.Notifies the server that this client is ready to receive updates. This method is used by durable clients to notify servers that they are ready to receive updates. As soon as the server receives this message, it will forward updates to this client (if necessary).Durable clients must call this method after they are done creating regions. If it is called before the client creates the regions then updates will be lost. Any time a new Poolis created and regions have been added to it then this method needs to be called again.- Throws:
- java.lang.IllegalStateException- if called by a non-durable client
- Since:
- GemFire 5.5
 
 - 
createGatewaySenderFactoryGatewaySenderFactory createGatewaySenderFactory() CreatesGatewaySenderFactoryfor creating a SerialGatewaySender- Specified by:
- createGatewaySenderFactoryin interface- GemFireCache
- Returns:
- a GatewaySenderFactory
- Since:
- GemFire 7.0
 
 - 
createAsyncEventQueueFactoryAsyncEventQueueFactory createAsyncEventQueueFactory() CreatesAsyncEventQueueFactoryfor creating a AsyncEventQueue- Returns:
- a AsyncEventQueueFactory
- Since:
- GemFire 7.0
 
 - 
createGatewayReceiverFactoryGatewayReceiverFactory createGatewayReceiverFactory() CreatesGatewayReceiverFactoryfor creating a GatewayReceiver- Returns:
- a GatewayReceiverFactory
- Since:
- GemFire 7.0
 
 - 
getGatewaySendersjava.util.Set<GatewaySender> getGatewaySenders() Returns allGatewaySenders for this Cache.- Returns:
- Set of GatewaySenders
- Since:
- GemFire 7.0
 
 - 
getGatewaySenderGatewaySender getGatewaySender(java.lang.String id) Returns theGatewaySenderwith the given id added to this Cache.- Parameters:
- id- the id of the- GatewaySender
- Returns:
- GatewaySender with id
- Since:
- GemFire 7.0
 
 - 
getGatewayReceiversjava.util.Set<GatewayReceiver> getGatewayReceivers() Returns allGatewayReceivers for this Cache- Returns:
- Set of GatewaySenders
- Since:
- GemFire 7.0
 
 - 
getAsyncEventQueuesjava.util.Set<AsyncEventQueue> getAsyncEventQueues() Returns allAsyncEventQueues for this Cache- Returns:
- Set of AsyncEventQueue
- Since:
- GemFire 7.0
 
 - 
getAsyncEventQueueAsyncEventQueue getAsyncEventQueue(java.lang.String id) Returns theAsyncEventQueuewith the given id added to this Cache.- Parameters:
- id- the id of the- AsyncEventQueue
- Returns:
- AsyncEventQueue with id
- Since:
- GemFire 7.0
 
 - 
getMembersjava.util.Set<DistributedMember> getMembers() Returns a set of the other non-administrative members in the distributed system.- Returns:
- a set of the other non-administrative members in the distributed system
- Since:
- GemFire 6.6
 
 - 
getAdminMembersdefault java.util.Set<DistributedMember> getAdminMembers() Deprecated.as of 10.1 use themanagementpackage insteadReturns an empty set since deprecated Admin-only members have been removed.- Returns:
- an empty set.
- Since:
- GemFire 6.6
 
 - 
getMembersjava.util.Set<DistributedMember> getMembers(Region region) Returns a set of the members in the distributed system that have the given region. For regions with local scope an empty set is returned.- Parameters:
- region- a Region in the cache
- Returns:
- a set of the members in the distributed system that have the given region
- Since:
- GemFire 6.6
 
 - 
getSnapshotServiceCacheSnapshotService getSnapshotService() Obtains the snapshot service to allow the cache data to be imported or exported.- Returns:
- the snapshot service
 
 - 
isReconnectingboolean isReconnecting() Test to see whether the Cache is in the process of reconnecting and recreating a new cache after it has been removed from the system by other members or has shut down due to missing Roles and is reconnecting.This will also return true if the Cache has finished reconnecting. When reconnect has completed you can use getReconnectedCache()to retrieve the new cache instance.- Returns:
- true if the Cache is attempting to reconnect or has finished reconnecting
 
 - 
waitUntilReconnectedboolean waitUntilReconnected(long time, java.util.concurrent.TimeUnit units) throws java.lang.InterruptedExceptionWait for the Cache to finish reconnecting to the distributed system and recreate a new Cache. This may throw a CacheClosedException if reconnect attempts fail due to an exception. The exception will detail what went wrong.- Parameters:
- time- amount of time to wait, or -1 to wait forever
- units- time unit
- Returns:
- true if the cache was reconnected
- Throws:
- java.lang.InterruptedException- if the thread is interrupted while waiting
- See Also:
- getReconnectedCache()
 
 - 
stopReconnectingvoid stopReconnecting() Force the Cache to stop reconnecting. If the Cache is currently connected this will disconnect and close it.
 - 
getReconnectedCacheCache getReconnectedCache() Returns the new Cache if there was an auto-reconnect and the cache was recreated.- Returns:
- the new Cache if there was an auto-reconnect and the cache was recreated
 
 
- 
 
- 
