Package org.nuxeo.lib.stream.log.mem
Class MemCompoundLogTailer<M extends Externalizable>
java.lang.Object
org.nuxeo.lib.stream.log.mem.MemCompoundLogTailer<M>
- All Implemented Interfaces:
- AutoCloseable,- LogTailer<M>
A compound tailer to handle multiple partitions.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionReturns the list of Log name, partitions tuples currently assigned to this tailer.voidclose()booleanclosed()Returnstrueif the tailer has been closed.voidcommit()Commit current positions for all partitions (last message offset returned by read).commit(LogPartition partition) Commit current position for the partition.getCodec()Returns the codec used to read the records.group()Returns the consumer group.offsetForTimestamp(LogPartition partition, long timestamp) Look up the offset for the given partition by timestamp.read()Read a message from assigned partitions within the timeout.voidreset()Reset all committed positions for this group, next read will be done from beginning.voidreset(LogPartition partition) Reset the committed position for this group on this partition, next read for this partition will be done from the beginning.voidSet the current position for a single partition.voidtoEnd()Set the current positions to the end of all partitions.voidSet the current positions to previously committed positions.voidtoStart()Set the current positions to the beginning of all partitions.
- 
Constructor Details- 
MemCompoundLogTailer
 
- 
- 
Method Details- 
readDescription copied from interface:LogTailerRead a message from assigned partitions within the timeout.- Specified by:
- readin interface- LogTailer<M extends Externalizable>
- Returns:
- null if there is no message in the queue after the timeout.
- Throws:
- InterruptedException
 
- 
read
- 
commitDescription copied from interface:LogTailerCommit current position for the partition.- Specified by:
- commitin interface- LogTailer<M extends Externalizable>
- Returns:
- the committed offset, can return null if there was no previous read done on this partition.
 
- 
commitpublic void commit()Description copied from interface:LogTailerCommit current positions for all partitions (last message offset returned by read).- Specified by:
- commitin interface- LogTailer<M extends Externalizable>
 
- 
toEndpublic void toEnd()Description copied from interface:LogTailerSet the current positions to the end of all partitions.- Specified by:
- toEndin interface- LogTailer<M extends Externalizable>
 
- 
toStartpublic void toStart()Description copied from interface:LogTailerSet the current positions to the beginning of all partitions.- Specified by:
- toStartin interface- LogTailer<M extends Externalizable>
 
- 
toLastCommittedpublic void toLastCommitted()Description copied from interface:LogTailerSet the current positions to previously committed positions.- Specified by:
- toLastCommittedin interface- LogTailer<M extends Externalizable>
 
- 
assignmentsDescription copied from interface:LogTailerReturns the list of Log name, partitions tuples currently assigned to this tailer. Assignments can change only if the tailer has been created usingLogManager.subscribe(org.nuxeo.lib.stream.log.Name, java.util.Collection<org.nuxeo.lib.stream.log.Name>, org.nuxeo.lib.stream.log.RebalanceListener, org.nuxeo.lib.stream.codec.Codec<M>).- Specified by:
- assignmentsin interface- LogTailer<M extends Externalizable>
 
- 
groupDescription copied from interface:LogTailerReturns the consumer group.- Specified by:
- groupin interface- LogTailer<M extends Externalizable>
 
- 
closedpublic boolean closed()Description copied from interface:LogTailerReturnstrueif the tailer has been closed.- Specified by:
- closedin interface- LogTailer<M extends Externalizable>
 
- 
getCodecDescription copied from interface:LogTailerReturns the codec used to read the records. A null codec is the default legacy encoding.- Specified by:
- getCodecin interface- LogTailer<M extends Externalizable>
 
- 
seekDescription copied from interface:LogTailerSet the current position for a single partition. Do not change other partitions positions.- Specified by:
- seekin interface- LogTailer<M extends Externalizable>
 
- 
offsetForTimestampDescription copied from interface:LogTailerLook up the offset for the given partition by timestamp. The position is the earliest offset whose timestamp is greater than or equal to the given timestamp.The timestamp used depends on the implementation, for Kafka this is the LogAppendTime. Returns null if no record offset is found with an appropriate timestamp. - Specified by:
- offsetForTimestampin interface- LogTailer<M extends Externalizable>
 
- 
resetpublic void reset()Description copied from interface:LogTailerReset all committed positions for this group, next read will be done from beginning.- Specified by:
- resetin interface- LogTailer<M extends Externalizable>
 
- 
resetDescription copied from interface:LogTailerReset the committed position for this group on this partition, next read for this partition will be done from the beginning.- Specified by:
- resetin interface- LogTailer<M extends Externalizable>
 
- 
closepublic void close()- Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- LogTailer<M extends Externalizable>
 
 
-