Class FlakeIdGeneratorConfig
- All Implemented Interfaces:
- NamedConfig,- DataSerializable,- IdentifiedDataSerializable
FlakeIdGeneratorConfig contains the configuration for the member
 regarding Flake ID Generator.- Since:
- 3.10
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final longDefault value forgetAllowedFutureMillis().static final intDefault value forgetBitsNodeId().static final intDefault value forgetBitsSequence().static final longDefault value forgetEpochStart().static final intDefault value forgetPrefetchCount().static final longDefault value forgetPrefetchValidityMillis().static final intMaximum value for prefetch count.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionbooleanlongintintintReturns type identifier for this class.longintReturns DataSerializableFactory factory ID for this class.getName()Returns the configuration name.longintlonginthashCode()booleanvoidReads fields from the input streamsetAllowedFutureMillis(long allowedFutureMillis) Sets how far to the future is the generator allowed to go to generate IDs without blocking.setBitsNodeId(int bitsNodeId) Sets the bit-length of node id component.setBitsSequence(int bitsSequence) Sets the bit-length of the sequence component.setEpochStart(long epochStart) Sets the offset of timestamp component in milliseconds.Sets the name or name pattern for this config.setNodeIdOffset(long nodeIdOffset) Sets the offset that will be added to the node ID assigned to cluster member for this generator.setPrefetchCount(int prefetchCount) Sets how many IDs are pre-fetched on the background when one call toFlakeIdGenerator.newId()is made.setPrefetchValidityMillis(long prefetchValidityMs) Sets for how long the pre-fetched IDs can be used.setStatisticsEnabled(boolean statisticsEnabled) Enables or disables statistics gathering ofLocalFlakeIdGeneratorStats.toString()voidWrites object fields to output stream
- 
Field Details- 
DEFAULT_PREFETCH_COUNTpublic static final int DEFAULT_PREFETCH_COUNTDefault value forgetPrefetchCount().- See Also:
 
- 
DEFAULT_PREFETCH_VALIDITY_MILLISpublic static final long DEFAULT_PREFETCH_VALIDITY_MILLISDefault value forgetPrefetchValidityMillis().- See Also:
 
- 
DEFAULT_EPOCH_STARTpublic static final long DEFAULT_EPOCH_STARTDefault value forgetEpochStart().1514764800000is the valueSystem.currentTimeMillis()would return on 1.1.2018 0:00 UTC.- See Also:
 
- 
DEFAULT_BITS_SEQUENCEpublic static final int DEFAULT_BITS_SEQUENCEDefault value forgetBitsSequence().- See Also:
 
- 
DEFAULT_BITS_NODE_IDpublic static final int DEFAULT_BITS_NODE_IDDefault value forgetBitsNodeId().- See Also:
 
- 
DEFAULT_ALLOWED_FUTURE_MILLISpublic static final long DEFAULT_ALLOWED_FUTURE_MILLISDefault value forgetAllowedFutureMillis().- See Also:
 
- 
MAXIMUM_PREFETCH_COUNTpublic static final int MAXIMUM_PREFETCH_COUNTMaximum value for prefetch count. The limit is ~10% of the default time we allow the IDs to be from the future (seeDEFAULT_ALLOWED_FUTURE_MILLIS).The reason to limit the prefetch count is that a single call to FlakeIdGenerator.newId()might be blocked if the future allowance is exceeded: we want to avoid a single call for a large batch to block another call for a small batch.- See Also:
 
 
- 
- 
Constructor Details- 
FlakeIdGeneratorConfigpublic FlakeIdGeneratorConfig()
- 
FlakeIdGeneratorConfig
- 
FlakeIdGeneratorConfigCopy-constructor
 
- 
- 
Method Details- 
getNameReturns the configuration name. This can be actual object name or pattern.- Specified by:
- getNamein interface- NamedConfig
 
- 
setNameSets the name or name pattern for this config. Must not be modified after this instance is added toConfig.- Specified by:
- setNamein interface- NamedConfig
 
- 
getPrefetchCountpublic int getPrefetchCount()- See Also:
 
- 
setPrefetchCountSets how many IDs are pre-fetched on the background when one call toFlakeIdGenerator.newId()is made. Default is 100.This setting pertains only to newId()calls made on the member that configured it.- Parameters:
- prefetchCount- the desired prefetch count, in the range 1..100000.
- Returns:
- this instance for fluent API
 
- 
getPrefetchValidityMillispublic long getPrefetchValidityMillis()- See Also:
 
- 
setPrefetchValidityMillisSets for how long the pre-fetched IDs can be used. If this time elapses, a new batch of IDs will be fetched. Time unit is milliseconds, default is 600,000 (10 minutes).The IDs contain timestamp component, which ensures rough global ordering of IDs. If an ID is assigned to an object that was created much later, it will be much out of order. If you don't care about ordering, set this value to 0. This setting pertains only to newIdcalls made on the member that configured it.- Parameters:
- prefetchValidityMs- the desired ID validity or unlimited, if <=0
- Returns:
- this instance for fluent API
 
- 
setEpochStartSets the offset of timestamp component in milliseconds. By default, it's 1514764800000L, that is the beginning of 2018. You can adjust the value to determine the lifespan of the generator. SeeFlakeIdGenerator's class javadoc for more information.Note: If you set the epoch start to a future instant, negative IDs will be generated until that time occurs. - Parameters:
- epochStart- the desired epoch start
- Returns:
- this instance for fluent API
- Since:
- 4.0
 
- 
getEpochStartpublic long getEpochStart()- See Also:
 
- 
getNodeIdOffsetpublic long getNodeIdOffset()- See Also:
 
- 
setNodeIdOffsetSets the offset that will be added to the node ID assigned to cluster member for this generator. Might be useful in A/B deployment scenarios where you have cluster A which you want to upgrade. You create cluster B and for some time both will generate IDs and you want to have them unique. In this case, configure node ID offset for generators on cluster B.- Parameters:
- nodeIdOffset- the value added to the node id
- Returns:
- this instance for fluent API
- See Also:
 
- 
getBitsSequencepublic int getBitsSequence()- See Also:
 
- 
setBitsSequenceSets the bit-length of the sequence component. This setting determines the maximum rate at which IDs can be generated. SeeFlakeIdGenerator's class javadoc for more information.- Parameters:
- bitsSequence- sequence component bit-length
- Returns:
- this instance for fluent API
- Since:
- 4.0
 
- 
getBitsNodeIdpublic int getBitsNodeId()- See Also:
 
- 
setBitsNodeIdSets the bit-length of node id component. SeeFlakeIdGenerator's class javadoc for more information.- Parameters:
- bitsNodeId- node id component bit-length
- Returns:
- this instance for fluent API
- Since:
- 4.0
 
- 
getAllowedFutureMillispublic long getAllowedFutureMillis()- See Also:
 
- 
setAllowedFutureMillisSets how far to the future is the generator allowed to go to generate IDs without blocking.The number of bits configured for the sequence number ( setBitsSequence(int)determines how many IDs can be generated per second. We allow the generator to generate IDs with future timestamps, and this settings limits how much. When more IDs are requested, the call will block. This is important in case of a cluster black-out or cluster restart: we don't store how far the members went, and after they restart, they will start from current time. If before the restart the generator went beyond the current time, duplicate IDs could be generated.The default value is 15 seconds (15000). If your cluster is able to restart more quickly, set a lower value. See FlakeIdGenerator's class javadoc for more information.- Parameters:
- allowedFutureMillis- value in milliseconds
- Returns:
- this instance for fluent API
- Since:
- 4.0
 
- 
isStatisticsEnabledpublic boolean isStatisticsEnabled()- See Also:
 
- 
setStatisticsEnabledEnables or disables statistics gathering ofLocalFlakeIdGeneratorStats.- Parameters:
- statisticsEnabled-- trueif statistics gathering is enabled (which is also the default),- falseotherwise
- Returns:
- this instance for fluent API
 
- 
equals
- 
hashCodepublic 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.
 
 
-