Package com.hazelcast.config
Class MapConfig
java.lang.Object
com.hazelcast.config.MapConfig
- All Implemented Interfaces:
- NamedConfig,- UserCodeNamespaceAwareConfig<MapConfig>,- DataSerializable,- IdentifiedDataSerializable,- com.hazelcast.nio.serialization.impl.Versioned
public class MapConfig
extends Object
implements IdentifiedDataSerializable, NamedConfig, com.hazelcast.nio.serialization.impl.Versioned, UserCodeNamespaceAwareConfig<MapConfig>
Contains the configuration for an 
IMap.- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intThe default number of backupsstatic final CacheDeserializedValuesWe want to cache values only when an index is defined.static final booleanDefault value of whether per entry statistics are enabled or notstatic final EvictionPolicyDefault eviction policystatic final InMemoryFormatDefault In-Memory format is binary.static final intThe number of default time to wait eviction in seconds.static final intDefault max size.static final MaxSizePolicyDefault max size policystatic final MetadataPolicyDefault metadata policystatic final booleanDefault value of whether statistics are enabled or notstatic final intThe number of default Time to Live in seconds.static final intThe number of Time to Live that represents disabling TTL.static final intThe maximum number of backupsstatic final intThe minimum number of backupsFields inherited from interface com.hazelcast.config.UserCodeNamespaceAwareConfigDEFAULT_NAMESPACE
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionaddAttributeConfig(AttributeConfig attributeConfig) addEntryListenerConfig(EntryListenerConfig listenerConfig) addIndexConfig(IndexConfig indexConfig) addMapPartitionLostListenerConfig(MapPartitionLostListenerConfig listenerConfig) addQueryCacheConfig(QueryCacheConfig queryCacheConfig) Adds a newQueryCacheConfigto thisMapConfig.final booleanintReturns the asynchronous backup count for thisIMap.intReturns the backupCount for thisIMapGet current value cache settingsintReturns type identifier for this class.Gets theDataPersistenceConfigfor thisMapConfigGets theEventJournalConfigfor thisMapConfigGets theEvictionConfiginstance of the eviction configuration for thisIMap.intReturns DataSerializableFactory factory ID for this class.Gets theHotRestartConfigfor thisMapConfigReturns the data type that will be used for storing records.Returns the map store configurationintReturns the maximum number of seconds for each entry to stay idle in the map.Gets theMergePolicyConfigfor this map.Gets theMerkleTreeConfigfor thisMapConfigReturnsMetadataPolicyfor this map.getName()Returns the name of thisIMapReturns the Near Cache configurationGet Partition Attribute configs used for creation ofAttributePartitioningStrategyReturns allQueryCacheConfiginstances defined on thisMapConfig.Gets theTieredStoreConfigfor thisMapConfigintReturns the maximum number of seconds for each entry to stay in the map.intReturns the total number of backups: backupCount plus asyncBackupCount.Retrieve the User Code Deployment Namespace to be used forClassLoaderawareness during operations related to the structure associated with this configuration.Gets the WAN target replication reference.final inthashCode()booleanChecks if Near Cache is enabled.booleanChecks if entry level statistics are enabled for this map.booleanChecks if read-backup-data (reading local backup entries) is enabled for this map.booleanChecks if statistics are enabled for this map.voidReads fields from the input streamsetAsyncBackupCount(int asyncBackupCount) Sets the number of asynchronous backups. 0 means no backups.setAttributeConfigs(List<AttributeConfig> attributeConfigs) setBackupCount(int backupCount) Number of synchronous backups.setCacheDeserializedValues(CacheDeserializedValues cacheDeserializedValues) Configure de-serialized value caching.setDataPersistenceConfig(DataPersistenceConfig dataPersistenceConfig) Sets theDataPersistenceConfigfor thisMapConfigsetEntryListenerConfigs(List<EntryListenerConfig> listenerConfigs) setEventJournalConfig(EventJournalConfig eventJournalConfig) Sets theEventJournalConfigfor thisMapConfigsetEvictionConfig(EvictionConfig evictionConfig) Sets theEvictionConfiginstance for eviction configuration for thisIMap.setHotRestartConfig(HotRestartConfig hotRestartConfig) Deprecated.setIndexConfigs(List<IndexConfig> indexConfigs) setInMemoryFormat(InMemoryFormat inMemoryFormat) Binary type that will be used for storing records.setMapStoreConfig(MapStoreConfig mapStoreConfig) Sets the map store configurationsetMaxIdleSeconds(int maxIdleSeconds) Maximum number of seconds for each entry to stay idle in the map.setMergePolicyConfig(MergePolicyConfig mergePolicyConfig) Sets theMergePolicyConfigfor this map.setMerkleTreeConfig(MerkleTreeConfig merkleTreeConfig) Sets theMerkleTreeConfigfor thisMapConfigsetMetadataPolicy(MetadataPolicy metadataPolicy) Sets the metadata policy.Sets the name of theIMapsetNearCacheConfig(NearCacheConfig nearCacheConfig) Sets the Near Cache configurationsetPartitioningAttributeConfigs(List<PartitioningAttributeConfig> partitioningAttributeConfigs) setPartitioningStrategyConfig(PartitioningStrategyConfig partitioningStrategyConfig) setPartitionLostListenerConfigs(List<MapPartitionLostListenerConfig> listenerConfigs) setPerEntryStatsEnabled(boolean perEntryStatsEnabled) Set to enable/disable per entry statistics.setQueryCacheConfigs(List<QueryCacheConfig> queryCacheConfigs) SetsQueryCacheConfiginstances to thisMapConfig.setReadBackupData(boolean readBackupData) Sets read-backup-data (reading local backup entries) for this map.setSplitBrainProtectionName(String splitBrainProtectionName) setStatisticsEnabled(boolean statisticsEnabled) Set to enable/disable map level statistics for this map.setTieredStoreConfig(TieredStoreConfig tieredStoreConfig) Sets theTieredStoreConfigfor thisMapConfigsetTimeToLiveSeconds(int timeToLiveSeconds) The maximum number of seconds for each entry to stay in the map.setUserCodeNamespace(String userCodeNamespace) Associates the provided Namespace Name with this structure forClassLoaderawareness.setWanReplicationRef(WanReplicationRef wanReplicationRef) Sets the WAN target replication reference.toString()voidWrites object fields to output stream
- 
Field Details- 
MIN_BACKUP_COUNTpublic static final int MIN_BACKUP_COUNTThe minimum number of backups- See Also:
 
- 
DEFAULT_BACKUP_COUNTpublic static final int DEFAULT_BACKUP_COUNTThe default number of backups- See Also:
 
- 
MAX_BACKUP_COUNTpublic static final int MAX_BACKUP_COUNTThe maximum number of backups- See Also:
 
- 
DISABLED_TTL_SECONDSpublic static final int DISABLED_TTL_SECONDSThe number of Time to Live that represents disabling TTL.- See Also:
 
- 
DEFAULT_TTL_SECONDSpublic static final int DEFAULT_TTL_SECONDSThe number of default Time to Live in seconds.- See Also:
 
- 
DEFAULT_MAX_IDLE_SECONDSpublic static final int DEFAULT_MAX_IDLE_SECONDSThe number of default time to wait eviction in seconds.- See Also:
 
- 
DEFAULT_IN_MEMORY_FORMATDefault In-Memory format is binary.
- 
DEFAULT_CACHED_DESERIALIZED_VALUESWe want to cache values only when an index is defined.
- 
DEFAULT_METADATA_POLICYDefault metadata policy
- 
DEFAULT_STATISTICS_ENABLEDpublic static final boolean DEFAULT_STATISTICS_ENABLEDDefault value of whether statistics are enabled or not- See Also:
 
- 
DEFAULT_ENTRY_STATS_ENABLEDpublic static final boolean DEFAULT_ENTRY_STATS_ENABLEDDefault value of whether per entry statistics are enabled or not- See Also:
 
- 
DEFAULT_MAX_SIZEpublic static final int DEFAULT_MAX_SIZEDefault max size.- See Also:
 
- 
DEFAULT_MAX_SIZE_POLICYDefault max size policy
- 
DEFAULT_EVICTION_POLICYDefault eviction policy
 
- 
- 
Constructor Details- 
MapConfigpublic MapConfig()
- 
MapConfig
- 
MapConfig
 
- 
- 
Method Details- 
getNameReturns the name of thisIMap- Specified by:
- getNamein interface- NamedConfig
- Returns:
- the name of the IMap
 
- 
setNameSets the name of theIMap- Specified by:
- setNamein interface- NamedConfig
- Parameters:
- name- the name to set for this- IMap
 
- 
getInMemoryFormatReturns the data type that will be used for storing records.- Returns:
- data type that will be used for storing records
 
- 
setInMemoryFormatBinary type that will be used for storing records. Possible values:- BINARY (default): keys and values will be stored as binary data
- OBJECT: values will be stored in their object forms
- NATIVE: values will be stored in non-heap region of JVM (Hazelcast Enterprise only)
 - Parameters:
- inMemoryFormat- the record type to set for this- IMap
- Throws:
- IllegalArgumentException- if inMemoryFormat is- null
 
- 
getEvictionConfigGets theEvictionConfiginstance of the eviction configuration for thisIMap.- Returns:
- the EvictionConfiginstance of the eviction configuration
 
- 
setEvictionConfigSets theEvictionConfiginstance for eviction configuration for thisIMap.- Parameters:
- evictionConfig- the- EvictionConfiginstance to set for the eviction configuration
- Returns:
- current map config instance
 
- 
getBackupCountpublic int getBackupCount()Returns the backupCount for thisIMap- Returns:
- the backupCount for this IMap
- See Also:
 
- 
setBackupCountNumber of synchronous backups. For example, if 1 is set as the backup count, then all entries of the map will be copied to another JVM for fail-safety. 0 means no sync backup.- Parameters:
- backupCount- the number of synchronous backups to set for this- IMap
- Returns:
- the updated MapConfig
- See Also:
 
- 
getAsyncBackupCountpublic int getAsyncBackupCount()Returns the asynchronous backup count for thisIMap.- Returns:
- the asynchronous backup count
- See Also:
 
- 
setAsyncBackupCountSets the number of asynchronous backups. 0 means no backups.- Parameters:
- asyncBackupCount- the number of asynchronous synchronous backups to set
- Returns:
- the updated MapConfig
- Throws:
- IllegalArgumentException- if asyncBackupCount smaller than 0, or larger than the maximum number of backup or the sum of the backups and async backups is larger than the maximum number of backups
- See Also:
 
- 
getTotalBackupCountpublic int getTotalBackupCount()Returns the total number of backups: backupCount plus asyncBackupCount.- Returns:
- the total number of backups: synchronous + asynchronous
 
- 
getTimeToLiveSecondspublic int getTimeToLiveSeconds()Returns the maximum number of seconds for each entry to stay in the map.- Returns:
- the maximum number of seconds for each entry to stay in the map
 
- 
setTimeToLiveSecondsThe maximum number of seconds for each entry to stay in the map. Entries that are older than timeToLiveSeconds will be automatically evicted from the map. Updates on the entry will change the eviction time. Any integer between 0 and Integer.MAX_VALUE. 0 means infinite. Default is 0.- Parameters:
- timeToLiveSeconds- the timeToLiveSeconds to set
 
- 
getMaxIdleSecondspublic int getMaxIdleSeconds()Returns the maximum number of seconds for each entry to stay idle in the map.- Returns:
- the maximum number of seconds for each entry to stay idle in the map
 
- 
setMaxIdleSecondsMaximum number of seconds for each entry to stay idle in the map. Entries that are idle (not touched) for more thanmaxIdleSecondswill get automatically evicted from the map. Entry is touched ifget(),getAll(),put()orcontainsKey()is called. Any integer between0andInteger.MAX_VALUE.0means infinite. Default is0. The time precision is limited by 1 second. The MaxIdle that less than 1 second can lead to unexpected behaviour.- Parameters:
- maxIdleSeconds- the maxIdleSeconds (the maximum number of seconds for each entry to stay idle in the map) to set
 
- 
getMapStoreConfigReturns the map store configuration- Returns:
- the mapStoreConfig (map store configuration)
 
- 
setMapStoreConfigSets the map store configuration- Parameters:
- mapStoreConfig- the mapStoreConfig (map store configuration) to set
 
- 
getNearCacheConfigReturns the Near Cache configuration- Returns:
- the Near Cache configuration
 
- 
setNearCacheConfigSets the Near Cache configuration- Parameters:
- nearCacheConfig- the Near Cache configuration
- Returns:
- the updated map configuration
 
- 
getMergePolicyConfigGets theMergePolicyConfigfor this map.- Returns:
- the MergePolicyConfigfor this map
 
- 
setMergePolicyConfigSets theMergePolicyConfigfor this map.Note that you may need to enable per entry stats via setPerEntryStatsEnabled(boolean)to see all fields of entry view in yourSplitBrainMergePolicyimplementation.- Returns:
- the updated map configuration
 
- 
isStatisticsEnabledpublic boolean isStatisticsEnabled()Checks if statistics are enabled for this map.- Returns:
- trueif statistics are enabled,- falseotherwise
 
- 
setStatisticsEnabledSet to enable/disable map level statistics for this map.This setting is only for map level stats such as last access time to map, total number of hits etc. For entry level stats see perEntryStatsEnabled- Parameters:
- statisticsEnabled-- trueto enable map statistics,- falseto disable
- Returns:
- the current map config instance
- See Also:
 
- 
isPerEntryStatsEnabledpublic boolean isPerEntryStatsEnabled()Checks if entry level statistics are enabled for this map.- Returns:
- trueif entry level statistics are enabled,- falseotherwise
- Since:
- 4.2
 
- 
setPerEntryStatsEnabledSet to enable/disable per entry statistics. Its default value isfalse.When you enable per entry stats, you can retrieve entry level statistics such as hits, creation time, last access time, last update time, last stored time for an entry. - Parameters:
- perEntryStatsEnabled-- trueto enable entry level statistics,- falseto disable
- Returns:
- the current map config instance
- Since:
- 4.2
 
- 
isReadBackupDatapublic boolean isReadBackupData()Checks if read-backup-data (reading local backup entries) is enabled for this map.- Returns:
- trueif read-backup-data is enabled,- falseotherwise
 
- 
setReadBackupDataSets read-backup-data (reading local backup entries) for this map.- Parameters:
- readBackupData-- trueto enable read-backup-data,- falseto disable
- Returns:
- the current map config instance
 
- 
getWanReplicationRefGets the WAN target replication reference.- Returns:
- the WAN target replication reference
 
- 
setWanReplicationRefSets the WAN target replication reference.- Parameters:
- wanReplicationRef- the WAN target replication reference
- Returns:
- the current map config instance
 
- 
addEntryListenerConfig
- 
getEntryListenerConfigs
- 
setEntryListenerConfigs
- 
addMapPartitionLostListenerConfig
- 
getPartitionLostListenerConfigs
- 
setPartitionLostListenerConfigspublic MapConfig setPartitionLostListenerConfigs(List<MapPartitionLostListenerConfig> listenerConfigs) 
- 
addIndexConfig
- 
getIndexConfigs
- 
setIndexConfigs
- 
addAttributeConfig
- 
getAttributeConfigs
- 
setAttributeConfigs
- 
getMetadataPolicyReturnsMetadataPolicyfor this map.- Returns:
- MetadataPolicyfor this map
 
- 
setMetadataPolicySets the metadata policy. SeeMetadataPolicyfor more information.- Parameters:
- metadataPolicy- the metadata policy
 
- 
addQueryCacheConfigAdds a newQueryCacheConfigto thisMapConfig.- Parameters:
- queryCacheConfig- the config to be added
- Returns:
- this MapConfiginstance
- Throws:
- IllegalArgumentException- if there is already a- QueryCachewith the same- QueryCacheConfig#name
 
- 
getQueryCacheConfigsReturns allQueryCacheConfiginstances defined on thisMapConfig.- Returns:
- all QueryCacheConfiginstances defined on thisMapConfig
 
- 
setQueryCacheConfigsSetsQueryCacheConfiginstances to thisMapConfig.- Returns:
- this configuration
 
- 
getPartitioningStrategyConfig
- 
setPartitioningStrategyConfigpublic MapConfig setPartitioningStrategyConfig(PartitioningStrategyConfig partitioningStrategyConfig) 
- 
isNearCacheEnabledpublic boolean isNearCacheEnabled()Checks if Near Cache is enabled.- Returns:
- trueif Near Cache is enabled,- falseotherwise
 
- 
setCacheDeserializedValuesConfigure de-serialized value caching. Default:CacheDeserializedValues.INDEX_ONLY- Returns:
- this MapConfiginstance
- Since:
- 3.6
- See Also:
 
- 
getHotRestartConfigGets theHotRestartConfigfor thisMapConfig- Returns:
- hot restart config
 
- 
getDataPersistenceConfigGets theDataPersistenceConfigfor thisMapConfig- Returns:
- dataPersistenceConfig config
 
- 
setHotRestartConfigDeprecated.since 5.0 usesetDataPersistenceConfig(DataPersistenceConfig)Sets theHotRestartConfigfor thisMapConfig- Parameters:
- hotRestartConfig- hot restart config
- Returns:
- this MapConfiginstance
 
- 
setDataPersistenceConfigSets theDataPersistenceConfigfor thisMapConfig- Parameters:
- dataPersistenceConfig- dataPersistenceConfig config
- Returns:
- this MapConfiginstance
 
- 
getMerkleTreeConfigGets theMerkleTreeConfigfor thisMapConfig- Returns:
- merkle tree config
 
- 
setMerkleTreeConfigSets theMerkleTreeConfigfor thisMapConfig- Parameters:
- merkleTreeConfig- merkle tree config
- Returns:
- this MapConfiginstance
 
- 
getEventJournalConfigGets theEventJournalConfigfor thisMapConfig- Returns:
- event journal config
 
- 
setEventJournalConfigSets theEventJournalConfigfor thisMapConfig- Parameters:
- eventJournalConfig- event journal config
- Returns:
- this MapConfiginstance
 
- 
getTieredStoreConfigGets theTieredStoreConfigfor thisMapConfig- Returns:
- tiered-store config
 
- 
setTieredStoreConfigSets theTieredStoreConfigfor thisMapConfig- Parameters:
- tieredStoreConfig- tiered-store config
- Returns:
- this MapConfiginstance
 
- 
getCacheDeserializedValuesGet current value cache settings- Returns:
- current value cache settings
- Since:
- 3.6
 
- 
getSplitBrainProtectionName
- 
setSplitBrainProtectionName
- 
getPartitioningAttributeConfigsGet Partition Attribute configs used for creation ofAttributePartitioningStrategy- Returns:
- list of partitioning attribute configs
 
- 
setPartitioningAttributeConfigspublic MapConfig setPartitioningAttributeConfigs(List<PartitioningAttributeConfig> partitioningAttributeConfigs) 
- 
getUserCodeNamespaceRetrieve the User Code Deployment Namespace to be used forClassLoaderawareness during operations related to the structure associated with this configuration.- Specified by:
- getUserCodeNamespacein interface- UserCodeNamespaceAwareConfig<MapConfig>
- Returns:
- Namespace Name for use with the UserCodeNamespaceService, ornullif there is no User Code Namespace to associate with.
 
- 
setUserCodeNamespaceAssociates the provided Namespace Name with this structure forClassLoaderawareness.The behaviour of setting this to nullis outlined in the documentation forUserCodeNamespaceAwareConfig.DEFAULT_NAMESPACE.- Specified by:
- setUserCodeNamespacein interface- UserCodeNamespaceAwareConfig<MapConfig>
- Parameters:
- userCodeNamespace- The ID of the Namespace to associate with this structure.
- Returns:
- the updated MapConfiginstance
- Since:
- 5.4
 
- 
equals
- 
hashCodepublic final int hashCode()
- 
toString
- 
getFactoryIdpublic int getFactoryId()Description copied from interface:IdentifiedDataSerializableReturns DataSerializableFactory factory ID for this class.- Specified by:
- getFactoryIdin interface- IdentifiedDataSerializable
- Returns:
- factory ID
 
- 
getClassIdpublic int getClassId()Description copied from interface:IdentifiedDataSerializableReturns type identifier for this class. It should be unique per DataSerializableFactory.- Specified by:
- getClassIdin interface- IdentifiedDataSerializable
- Returns:
- type ID
 
- 
writeDataDescription copied from interface:DataSerializableWrites object fields to output stream- Specified by:
- writeDatain interface- DataSerializable
- Parameters:
- out- output
- Throws:
- IOException- if an I/O error occurs. In particular, an- IOExceptionmay be thrown if the output stream has been closed.
 
- 
readDataDescription copied from interface:DataSerializableReads fields from the input stream- Specified by:
- readDatain interface- DataSerializable
- Parameters:
- in- input
- Throws:
- IOException- if an I/O error occurs. In particular, an- IOExceptionmay be thrown if the input stream has been closed.
 
 
- 
setDataPersistenceConfig(DataPersistenceConfig)