public class InMemoryTokenStore extends Object implements TokenStore
TokenStore that stores tracking tokens in memory. This implementation is thread-safe.| Constructor and Description | 
|---|
| InMemoryTokenStore() | 
| Modifier and Type | Method and Description | 
|---|---|
| void | deleteToken(String processorName,
           int segment)Deletes the token for the processor with given  processorNameandsegment. | 
| int[] | fetchSegments(String processorName)Returns an array of known  segmentsfor a givenprocessorName. | 
| TrackingToken | fetchToken(String processorName,
          int segment) | 
| void | initializeSegment(TrackingToken token,
                 String processorName,
                 int segment)Initializes a segment with given  segmentfor the processor with givenprocessorNameto contain
 the giventoken. | 
| void | initializeTokenSegments(String processorName,
                       int segmentCount)Initializes the given  segmentCountnumber of segments for the givenprocessorNameto track its
 tokens. | 
| void | initializeTokenSegments(String processorName,
                       int segmentCount,
                       TrackingToken initialToken)Initializes the given  segmentCountnumber of segments for the givenprocessorNameto track its
 tokens. | 
| void | releaseClaim(String processorName,
            int segment)Release a claim of the token for given  processorNameandsegment. | 
| boolean | requiresExplicitSegmentInitialization()Indicates whether this TokenStore instance requires segments to be explicitly initialized, before any tokens
 can be claimed for that segment. | 
| Optional<String> | retrieveStorageIdentifier()Returns a unique identifier that uniquely identifies the storage location of the tokens in this store. | 
| void | storeToken(TrackingToken token,
          String processorName,
          int segment)Stores the given  tokenin the store. | 
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitextendClaim, fetchAvailableSegments, fetchTokenpublic void initializeTokenSegments(@Nonnull String processorName, int segmentCount) throws UnableToClaimTokenException
TokenStoresegmentCount number of segments for the given processorName to track its
 tokens. This method should only be invoked when no tokens have been stored for the given processor, yet.
 
 This method will initialize the tokens, but not claim them. It will create the segments ranging from 0
 until segmentCount - 1.
 
The exact behavior when this method is called while tokens were already present, is undefined in case the token already present is not owned by the initializing process.
initializeTokenSegments in interface TokenStoreprocessorName - The name of the processor to initialize segments forsegmentCount - The number of segments to initializeUnableToClaimTokenException - when a segment has already been createdpublic void initializeTokenSegments(@Nonnull String processorName, int segmentCount, TrackingToken initialToken) throws UnableToClaimTokenException
TokenStoresegmentCount number of segments for the given processorName to track its
 tokens. This method should only be invoked when no tokens have been stored for the given processor, yet.
 
 This method will store initialToken for all segments as starting point for processor, but not claim them.
 It will create the segments ranging from 0 until segmentCount - 1.
 
The exact behavior when this method is called while tokens were already present, is undefined in case the token already present is not owned by the initializing process.
initializeTokenSegments in interface TokenStoreprocessorName - The name of the processor to initialize segments forsegmentCount - The number of segments to initializeinitialToken - The initial token which is used as a starting point for processorUnableToClaimTokenException - when a segment has already been createdpublic void storeToken(TrackingToken token, @Nonnull String processorName, int segment)
TokenStoretoken in the store. The token marks the current position of the process with given
 processorName and segment. The given token may be null.
 
 Any claims made by the current process have their timestamp updated.
 
 This method should throw an UnableToClaimTokenException when the given segment has not been
 initialized with a Token (albeit null) yet. In that case, a segment must have been explicitly initialized.
 A TokenStore implementation's ability to do so is exposed by the TokenStore.requiresExplicitSegmentInitialization()
 method. If that method returns false, this method may implicitly initialize a token and return that token upon
 invocation.
storeToken in interface TokenStoretoken - The token to store for a given process and segment. May be null.processorName - The name of the process for which to store the tokensegment - The index of the segment for which to store the tokenpublic TrackingToken fetchToken(@Nonnull String processorName, int segment)
TokenStoretoken for the given processorName and segment.
 Returns null if the stored token for the given process and segment is
 null.
 
 This method should throw an UnableToClaimTokenException when the given segment has not been
 initialized with a Token (albeit null) yet. In that case, a segment must have been explicitly initialized.
 A TokenStore implementation's ability to do so is exposed by the TokenStore.requiresExplicitSegmentInitialization()
 method. If that method returns false, this method may implicitly initialize a token and return that token upon
 invocation.
 
 The token will be claimed by the current process (JVM instance), preventing access by other instances. To release
 the claim, use TokenStore.releaseClaim(String, int)
fetchToken in interface TokenStoreprocessorName - The process name for which to fetch the tokensegment - The segment index for which to fetch the tokennull if the store holds no token for given process and segmentpublic void releaseClaim(@Nonnull String processorName, int segment)
TokenStoreprocessorName and segment. If no such claim existed,
 nothing happens.
 The caller must ensure not to use any streams opened based on the token for which the claim is released.
releaseClaim in interface TokenStoreprocessorName - The name of the process owning the token (e.g. a TrackingEventProcessor name)segment - the segment for which a token was obtainedpublic void deleteToken(@Nonnull String processorName, int segment) throws UnableToClaimTokenException
TokenStoreprocessorName and segment. The token must
 be owned by the current node, to be able to delete it.
 
 Implementations should implement this method only when TokenStore.requiresExplicitSegmentInitialization() is overridden to
 return true. Deleting tokens using implementations that do not require explicit token initialization is
 unsafe, as a claim will automatically recreate the deleted token instance, which may result in concurrency
 issues.
deleteToken in interface TokenStoreprocessorName - The name of the processor to remove the token forsegment - The segment to deleteUnableToClaimTokenException - if the token is not currently claimed by this nodepublic void initializeSegment(TrackingToken token, @Nonnull String processorName, int segment) throws UnableToInitializeTokenException
TokenStoresegment for the processor with given processorName to contain
 the given token.
 This method fails if a Token already exists for the given processor and segment, even if that token has been claimed by the active instance.
 This method will not claim the initialized segment. Use TokenStore.fetchToken(String, int) to retrieve and claim
 the token.
initializeSegment in interface TokenStoretoken - The token to initialize the segment withprocessorName - The name of the processor to create the segment forsegment - The identifier of the segment to initializeUnableToInitializeTokenException - if a Token already existspublic boolean requiresExplicitSegmentInitialization()
TokenStorerequiresExplicitSegmentInitialization in interface TokenStoretrue if this instance requires tokens to be explicitly initialized, otherwise false.TokenStore.initializeTokenSegments(String, int), 
TokenStore.initializeTokenSegments(String, int, TrackingToken), 
TokenStore.initializeSegment(TrackingToken, String, int)public int[] fetchSegments(@Nonnull String processorName)
TokenStoresegments for a given processorName.
 
 The segments returned are segments for which a token has been stored previously. When the TokenStore is
 empty, an empty array is returned.
fetchSegments in interface TokenStoreprocessorName - The process name for which to fetch the segmentspublic Optional<String> retrieveStorageIdentifier()
TokenStore
 Note that this method may require the implementation to consult its underlying storage. Therefore, a Transaction
 should be active when this method is called, similarly to invocations like TokenStore.fetchToken(String, int),
 TokenStore.fetchSegments(String), etc. When no Transaction is active, the behavior is undefined.
retrieveStorageIdentifier in interface TokenStoreCopyright © 2010–2023. All rights reserved.