Class ComposedSegmentedLoadWriteStore<K,V,T extends AbstractSegmentedStoreConfiguration>  
- All Implemented Interfaces:
- Lifecycle,- AdvancedCacheExpirationWriter<K,,- V> - AdvancedCacheLoader<K,,- V> - AdvancedCacheWriter<K,,- V> - AdvancedLoadWriteStore<K,,- V> - CacheLoader<K,,- V> - CacheWriter<K,,- V> - ExternalStore<K,,- V> - SegmentedAdvancedLoadWriteStore<K,- V> 
AbstractSegmentedStoreConfiguration.- Since:
- 9.4
- Author:
- wburns
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.infinispan.persistence.spi.AdvancedCacheExpirationWriterAdvancedCacheExpirationWriter.ExpirationPurgeListener<K,V> Nested classes/interfaces inherited from interface org.infinispan.persistence.spi.AdvancedCacheWriterAdvancedCacheWriter.PurgeListener<K>
- 
Constructor SummaryConstructorsConstructorDescriptionComposedSegmentedLoadWriteStore(AbstractSegmentedStoreConfiguration<T> configuration) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddSegments(IntSet segments) Invoked when a node becomes an owner of the given segments.bulkUpdate(org.reactivestreams.Publisher<MarshallableEntry<? extends K, ? extends V>> publisher) Persist all provided entries to the store in chunks, with the size of each chunk determined by the store implementation.voidclear()Removes all the data from the storage.voidRemoves all the data that maps to the given segments from the storage.booleanReturns true if the storage contains an entry associated with the given key in the given segmentbooleanRemoves the entry for the provided key which is in the given segment.voiddeleteBatch(Iterable<Object> keys) Remove all provided keys from the store in a single batch operation.voiddestroy()Method to be used to destroy and clean up any resources associated with this store.org.reactivestreams.Publisher<MarshallableEntry<K,V>> entryPublisher(Predicate<? super K> filter, boolean fetchValue, boolean fetchMetadata) Publishes all entries from this store.org.reactivestreams.Publisher<MarshallableEntry<K,V>> entryPublisher(IntSet segments, Predicate<? super K> filter, boolean fetchValue, boolean fetchMetadata) Publishes all entries from this store.voidforEach(ObjIntConsumer<? super AdvancedLoadWriteStore> consumer) Method that allows user to directly invoke some method(s) on the underlying store.Fetches an entry from the storage given a segment to optimize this lookup based on.voidUsed to initialize a cache loader.org.reactivestreams.Publisher<K>publishKeys(Predicate<? super K> filter) Publishes all the keys from this store.org.reactivestreams.Publisher<K>publishKeys(IntSet segments, Predicate<? super K> filter) Publishes all the keys that map to the given segments from this store.voidpurge(Executor executor, AdvancedCacheExpirationWriter.ExpirationPurgeListener<K, V> listener) Using the thread in the pool, removed all the expired data from the persistence storage.voidremoveSegments(IntSet segments) Invoked when a node loses ownership of a segment.intsize()Returns the number of elements in the store.intReturns the number of elements in the store that map to the given segments that aren't expired.voidstart()Invoked on component startvoidstop()Invoked on component stopvoidwrite(int segment, MarshallableEntry<? extends K, ? extends V> entry) Persists the entry to the storage with the given segment to optimize future lookups.Methods inherited from class org.infinispan.persistence.support.AbstractSegmentedAdvancedLoadWriteStorecontains, delete, loadEntry, writeMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.infinispan.persistence.spi.AdvancedCacheExpirationWriterpurgeMethods inherited from interface org.infinispan.persistence.spi.CacheWriterisAvailableMethods inherited from interface org.infinispan.persistence.spi.ExternalStoreisAvailable
- 
Constructor Details- 
ComposedSegmentedLoadWriteStore
 
- 
- 
Method Details- 
getKeyMapper- Specified by:
- getKeyMapperin class- AbstractSegmentedAdvancedLoadWriteStore<K,- V> 
 
- 
getDescription copied from interface:SegmentedAdvancedLoadWriteStoreFetches an entry from the storage given a segment to optimize this lookup based on. If aMarshallableEntryneeds to be created here,InitializationContext.getMarshallableEntryFactory()andInitializationContext.getByteBufferFactory()should be used.The provided segment may be used for performance purposes, however it it is acceptable to ignore this argument. This method may be invoked invoked irrespective if the store is StoreConfiguration.segmented().- Parameters:
- segment- the segment that the key maps to
- key- the key of the entry to fetch
- Returns:
- the entry, or null if the entry does not exist
 
- 
containsDescription copied from interface:SegmentedAdvancedLoadWriteStoreReturns true if the storage contains an entry associated with the given key in the given segmentThe provided segment may be used for performance purposes, however it it is acceptable to ignore this argument. This method may be invoked invoked irrespective if the store is StoreConfiguration.segmented().- Parameters:
- segment- the segment that the key maps to
- key- the key to see if exists
- Returns:
- true if the key is present in this loader with a given segment
 
- 
writeDescription copied from interface:SegmentedAdvancedLoadWriteStorePersists the entry to the storage with the given segment to optimize future lookups.The provided segment may be used for performance purposes, however it it is acceptable to ignore this argument. This method may be invoked invoked irrespective if the store is StoreConfiguration.segmented().- Parameters:
- segment- the segment to persist this entry to
- entry- the entry to write to the store
- See Also:
 
- 
deleteDescription copied from interface:SegmentedAdvancedLoadWriteStoreRemoves the entry for the provided key which is in the given segment. This method then returns whether the entry was removed or not.The provided segment may be used for performance purposes, however it it is acceptable to ignore this argument. This method may be invoked invoked irrespective if the store is StoreConfiguration.segmented().- Parameters:
- segment- the segment that this key maps to
- key- the key of the entry to remove
- Returns:
- true if the entry existed in the persistent store and it was deleted.
 
- 
sizeDescription copied from interface:SegmentedAdvancedLoadWriteStoreReturns the number of elements in the store that map to the given segments that aren't expired.The segments here must be adhered to and the size must not count any entries that don't belong to the provided segments. This method is not invoked invoked when the store is not configured to be StoreConfiguration.segmented().- Parameters:
- segments- the segments which should have their entries counted. Always non null.
- Returns:
- the count of entries in the given segments
 
- 
sizepublic int size()Description copied from interface:AdvancedCacheLoaderReturns the number of elements in the store.
- 
publishKeysDescription copied from interface:SegmentedAdvancedLoadWriteStorePublishes all the keys that map to the given segments from this store. The given publisher can be used by as manySubscribers as desired. Keys are not retrieved until a given Subscriber requests them from theSubscription.Stores will return only non expired keys The segments here must be adhered to and the keys published must not include any that don't belong to the provided segments. This method is not invoked invoked when the store is not configured to be StoreConfiguration.segmented().- Parameters:
- segments- the segments that the keys must map to. Always non null.
- filter- a filter
- Returns:
- a publisher that will provide the keys from the store
 
- 
publishKeysDescription copied from interface:AdvancedCacheLoaderPublishes all the keys from this store. The given publisher can be used by as manySubscribers as desired. Keys are not retrieved until a given Subscriber requests them from theSubscription.Stores will return only non expired keys - Parameters:
- filter- a filter - null is treated as allowing all entries
- Returns:
- a publisher that will provide the keys from the store
 
- 
entryPublisherpublic org.reactivestreams.Publisher<MarshallableEntry<K,V>> entryPublisher(IntSet segments, Predicate<? super K> filter, boolean fetchValue, boolean fetchMetadata) Description copied from interface:SegmentedAdvancedLoadWriteStorePublishes all entries from this store. The given publisher can be used by as manySubscribers as desired. Entries are not retrieved until a given Subscriber requests them from theSubscription.If fetchMetadata is true this store must guarantee to not return any expired entries. The segments here must be adhered to and the entries published must not include any that don't belong to the provided segments. This method is not invoked invoked when the store is not configured to be StoreConfiguration.segmented().StoreConfiguration.segmented().- Parameters:
- segments- the segments that the keys of the entries must map to. Always non null.
- filter- a filter on the keys of the entries that if passed will allow the given entry to be returned from the publisher
- fetchValue- whether the value should be included in the marshalled entry
- fetchMetadata- whether the metadata should be included in the marshalled entry
- Returns:
- a publisher that will provide the entries from the store that map to the given segments
 
- 
entryPublisherpublic org.reactivestreams.Publisher<MarshallableEntry<K,V>> entryPublisher(Predicate<? super K> filter, boolean fetchValue, boolean fetchMetadata) Description copied from interface:AdvancedCacheLoaderPublishes all entries from this store. The given publisher can be used by as manySubscribers as desired. Entries are not retrieved until a given Subscriber requests them from theSubscription.If fetchMetadata is true this store must guarantee to not return any expired entries. - Parameters:
- filter- a filter - null is treated as allowing all entries
- fetchValue- whether or not to fetch the value from the persistent store. E.g. if the iteration is intended only over the key set, no point fetching the values from the persistent store as well
- fetchMetadata- whether or not to fetch the metadata from the persistent store. E.g. if the iteration is intended only ove the key set, then no point fetching the metadata from the persistent store as well
- Returns:
- a publisher that will provide the entries from the store
 
- 
clearpublic void clear()Description copied from interface:AdvancedCacheWriterRemoves all the data from the storage.
- 
purgepublic void purge(Executor executor, AdvancedCacheExpirationWriter.ExpirationPurgeListener<K, V> listener) Description copied from interface:SegmentedAdvancedLoadWriteStoreUsing the thread in the pool, removed all the expired data from the persistence storage. For each removed entry, the supplied listener is invoked. This should be preferred toAdvancedCacheWriter.purge(Executor, PurgeListener)since it allows for value and metadata to be provided which provides more accurate expiration when coordination is required.- Parameters:
- executor- the executor to invoke the given command on
- listener- the listener that is notified for each expired entry
 
- 
clearDescription copied from interface:SegmentedAdvancedLoadWriteStoreRemoves all the data that maps to the given segments from the storage.This method must only remove entries that map to the provided segments. This method may be invoked irrespective if the configuration is StoreConfiguration.segmented()or not.- Parameters:
- segments- data mapping to these segments are removed. Always non null.
 
- 
deleteBatchDescription copied from interface:CacheWriterRemove all provided keys from the store in a single batch operation. If this is not supported by the underlying store, then keys are removed from the store individually viaCacheWriter.delete(Object).- Parameters:
- keys- an Iterable of entry Keys to be removed from the store.
 
- 
bulkUpdatepublic CompletionStage<Void> bulkUpdate(org.reactivestreams.Publisher<MarshallableEntry<? extends K, ? extends V>> publisher) Description copied from interface:CacheWriterPersist all provided entries to the store in chunks, with the size of each chunk determined by the store implementation. If chunking is not supported by the underlying store, then entries are written to the store individually viaCacheWriter.write(MarshallableEntry).- Parameters:
- publisher- a- Publisherof- MarshallableEntryinstances
 
- 
initDescription copied from interface:CacheLoaderUsed to initialize a cache loader. Typically invoked by thePersistenceManagerwhen setting up cache loaders.
- 
startpublic void start()Description copied from interface:LifecycleInvoked on component start
- 
stoppublic void stop()Description copied from interface:LifecycleInvoked on component stop
- 
destroypublic void destroy()Description copied from interface:ExternalStoreMethod to be used to destroy and clean up any resources associated with this store. This is normally only useful for non shared stores.This method will ensure the store is stopped and properly cleans up all resources for it. 
- 
addSegmentsDescription copied from interface:SegmentedAdvancedLoadWriteStoreInvoked when a node becomes an owner of the given segments. Note this method is only invoked for non shared store implementations.This method may be invoked irrespective if the configuration is StoreConfiguration.segmented()or not.- Parameters:
- segments- segments to associate with this store
 
- 
removeSegmentsDescription copied from interface:SegmentedAdvancedLoadWriteStoreInvoked when a node loses ownership of a segment. The provided segments are the ones this node no longer owns. Note this method is only invoked for non shared store implementations.This method may be invoked irrespective if the configuration is StoreConfiguration.segmented()or not.StoreConfiguration.segmented().- Parameters:
- segments- segments that should no longer be associated with this store
 
- 
forEachMethod that allows user to directly invoke some method(s) on the underlying store. The segment that each store maps to is also provided as an argument to the consumer- Parameters:
- consumer- callback for every store that is currently installed
 
 
-