Package org.apache.lucene.index
Class SegmentInfos
java.lang.Object
org.apache.lucene.index.SegmentInfos
- All Implemented Interfaces:
- Cloneable,- Iterable<SegmentCommitInfo>
A collection of segmentInfo objects with methods for operating on those segments in relation to
 the file system.
 
The active segments in the index are stored in the segment info file, segments_N.
 There may be one or more segments_N files in the index; however, the one with the
 largest generation is the active one (when older segments_N files are present it's because they
 temporarily cannot be deleted, or a custom IndexDeletionPolicy is in use). This file
 lists each segment by name and has details about the codec and generation of deletes.
 
Files:
- segments_N: Header, LuceneVersion, Version, NameCounter, SegCount, MinSegmentLuceneVersion, <SegName, SegID, SegCodec, DelGen, DeletionCount, FieldInfosGen, DocValuesGen, UpdatesFiles>SegCount, CommitUserData, Footer
- Header --> IndexHeader
- LuceneVersion --> Which Lucene code Versionwas used for this commit, written as threevInt: major, minor, bugfix
- MinSegmentLuceneVersion --> Lucene code Versionof the oldest segment, written as threevInt: major, minor, bugfix; this is only written only if there's at least one segment
- NameCounter, SegCount, DeletionCount --> Int32
- Generation, Version, DelGen, Checksum, FieldInfosGen, DocValuesGen --> Int64
- SegID --> Int8ID_LENGTH
- SegName, SegCodec --> String
- CommitUserData --> Map<String,String>
- UpdatesFiles --> Map<Int32,Set<String>>
- Footer --> CodecFooter
- Version counts how often the index has been changed by adding or deleting documents.
- NameCounter is used to generate names for new segment files.
- SegName is the name of the segment, and is used as the file name prefix for all of the files that compose the segment's index.
- DelGen is the generation count of the deletes file. If this is -1, there are no deletes.
       Anything above zero means there are deletes stored by LiveDocsFormat.
- DeletionCount records the number of deleted documents in this segment.
- SegCodec is the nameof the Codec that encoded this segment.
- SegID is the identifier of the Codec that encoded this segment.
- CommitUserData stores an optional user-supplied opaque Map<String,String> that was
       passed to IndexWriter.setLiveCommitData(Iterable).
- FieldInfosGen is the generation count of the fieldInfos file. If this is -1, there are no
       updates to the fieldInfos in that segment. Anything above zero means there are updates to
       fieldInfos stored by FieldInfosFormat.
- DocValuesGen is the generation count of the updatable DocValues. If this is -1, there are
       no updates to DocValues in that segment. Anything above zero means there are updates to
       DocValues stored by DocValuesFormat.
- UpdatesFiles stores the set of files that were updated in that segment per field.
- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classUtility class for executing code that needs to do something with the current segments file.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionlongUsed to name new segments.Opaque Map<String, String> that user can specify during IndexWriter.commitlongCounts how often the index has been changed.static final intThe version at the time when 8.0 was released.static final intThe version that recorded SegmentCommitInfo IDs
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidadd(SegmentCommitInfo si) Appends the providedSegmentCommitInfo.voidaddAll(Iterable<SegmentCommitInfo> sis) Appends the providedSegmentCommitInfos.asList()Returns all contained segments as an unmodifiableListview.voidchanged()Call this before committing if changes have been made to the segments.voidclear()Clear allSegmentCommitInfos.clone()Returns a copy of this instance, also copying each SegmentInfo.final voidWrites and syncs to the Directory dir, taking care to remove the segments file on exceptionfiles(boolean includeSegmentsFile) Returns all file names referenced by SegmentInfo.static longgenerationFromSegmentsFileName(String fileName) Parse the generation off the segments file name and return it.Returns which LuceneVersionwrote this commit, or null if the version this index was written with did not directly record the version.longReturns current generation.byte[]getId()Since Lucene 5.0, every commit (segments_N) writes a unique id.intReturn the version major that was used to initially create the index.static PrintStreamReturnsinfoStream.static longgetLastCommitGeneration(String[] files) Get the generation of the most recent commit to the list of index files (N in the segments_N file).static longgetLastCommitGeneration(Directory directory) Get the generation of the most recent commit to the index in this directory (N in the segments_N file).static StringgetLastCommitSegmentsFileName(String[] files) Get the filename of the segments_N file for the most recent commit in the list of index files.static StringgetLastCommitSegmentsFileName(Directory directory) Get the filename of the segments_N file for the most recent commit to the index in this Directory.longReturns last succesfully read or written generation.Returns the version of the oldest segment, or null if there are no segments.Get the segments_N filename in use by this segment infos.ReturnuserDatasaved with this commit.longversion number when this SegmentInfos was generated.info(int i) ReturnsSegmentCommitInfoat the provided index.iterator()Returns an unmodifiableIteratorof contained segments in order.static final SegmentInfosreadCommit(Directory directory, String segmentFileName) Read a particular segmentFileName.static final SegmentInfosreadCommit(Directory directory, String segmentFileName, int minSupportedMajorVersion) Read a particular segmentFileName, as long as the commit'sgetIndexCreatedVersionMajor()is strictly greater than the provided minimum supported major version.static final SegmentInfosreadCommit(Directory directory, ChecksumIndexInput input, long generation) Read the commit from the providedChecksumIndexInput.static final SegmentInfosreadCommit(Directory directory, ChecksumIndexInput input, long generation, int minSupportedMajorVersion) Read the commit from the providedChecksumIndexInput.static final SegmentInfosreadLatestCommit(Directory directory) Find the latest commit (segments_N file) and load allSegmentCommitInfos.static final SegmentInfosreadLatestCommit(Directory directory, int minSupportedMajorVersion) Find the latest commit (segments_N file) and load allSegmentCommitInfos, as long as the commit'sgetIndexCreatedVersionMajor()is strictly greater than the provided minimum supported major version.booleanRemove the providedSegmentCommitInfo.static voidsetInfoStream(PrintStream infoStream) If non-null, information about retries when loading the segments file will be printed to this.voidsetNextWriteGeneration(long generation) Set the generation to be used for the next commitvoidsetUserData(Map<String, String> data, boolean doIncrementVersion) Sets the commit data.intsize()Returns number ofSegmentCommitInfos.toString()Returns readable description of this segment.intReturns sum of all segment's maxDocs.voidupdateGeneration(SegmentInfos other) Carry over generation numbers from another SegmentInfosvoidwrite(IndexOutput out) Write ourselves to the providedIndexOutputMethods inherited from class java.lang.Objectequals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface java.lang.IterableforEach, spliterator
- 
Field Details- 
VERSION_74public static final int VERSION_74The version at the time when 8.0 was released.- See Also:
 
- 
VERSION_86public static final int VERSION_86The version that recorded SegmentCommitInfo IDs- See Also:
 
- 
counterpublic long counterUsed to name new segments.
- 
versionpublic long versionCounts how often the index has been changed.
- 
userDataOpaque Map<String, String> that user can specify during IndexWriter.commit
 
- 
- 
Constructor Details- 
SegmentInfospublic SegmentInfos(int indexCreatedVersionMajor) Sole constructor.- Parameters:
- indexCreatedVersionMajor- the Lucene version major at index creation time, or 6 if the index was created before 7.0
 
 
- 
- 
Method Details- 
infoReturnsSegmentCommitInfoat the provided index.
- 
getLastCommitGenerationGet the generation of the most recent commit to the list of index files (N in the segments_N file).- Parameters:
- files- -- array of file names to check
 
- 
getLastCommitGenerationGet the generation of the most recent commit to the index in this directory (N in the segments_N file).- Parameters:
- directory- -- directory to search for the latest segments_N file
- Throws:
- IOException
 
- 
getLastCommitSegmentsFileNameGet the filename of the segments_N file for the most recent commit in the list of index files.- Parameters:
- files- -- array of file names to check
 
- 
getLastCommitSegmentsFileNameGet the filename of the segments_N file for the most recent commit to the index in this Directory.- Parameters:
- directory- -- directory to search for the latest segments_N file
- Throws:
- IOException
 
- 
getSegmentsFileNameGet the segments_N filename in use by this segment infos.
- 
generationFromSegmentsFileNameParse the generation off the segments file name and return it.
- 
getIdpublic byte[] getId()Since Lucene 5.0, every commit (segments_N) writes a unique id. This will return that id
- 
readCommitpublic static final SegmentInfos readCommit(Directory directory, String segmentFileName) throws IOException Read a particular segmentFileName. Note that this may throw an IOException if a commit is in process.- Parameters:
- directory- -- directory containing the segments file
- segmentFileName- -- segment file to load
- Throws:
- CorruptIndexException- if the index is corrupt
- IOException- if there is a low-level IO error
 
- 
readCommitpublic static final SegmentInfos readCommit(Directory directory, String segmentFileName, int minSupportedMajorVersion) throws IOException Read a particular segmentFileName, as long as the commit'sgetIndexCreatedVersionMajor()is strictly greater than the provided minimum supported major version. If the commit's version is older, anIndexFormatTooOldExceptionwill be thrown. Note that this may throw an IOException if a commit is in process.- Throws:
- IOException
 
- 
readCommitpublic static final SegmentInfos readCommit(Directory directory, ChecksumIndexInput input, long generation) throws IOException Read the commit from the providedChecksumIndexInput.- Throws:
- IOException
 
- 
readCommitpublic static final SegmentInfos readCommit(Directory directory, ChecksumIndexInput input, long generation, int minSupportedMajorVersion) throws IOException Read the commit from the providedChecksumIndexInput.- Throws:
- IOException
 
- 
readLatestCommitFind the latest commit (segments_N file) and load allSegmentCommitInfos.- Throws:
- IOException
 
- 
readLatestCommitpublic static final SegmentInfos readLatestCommit(Directory directory, int minSupportedMajorVersion) throws IOException Find the latest commit (segments_N file) and load allSegmentCommitInfos, as long as the commit'sgetIndexCreatedVersionMajor()is strictly greater than the provided minimum supported major version. If the commit's version is older, anIndexFormatTooOldExceptionwill be thrown.- Throws:
- IOException
 
- 
writeWrite ourselves to the providedIndexOutput- Throws:
- IOException
 
- 
cloneReturns a copy of this instance, also copying each SegmentInfo.
- 
getVersionpublic long getVersion()version number when this SegmentInfos was generated.
- 
getGenerationpublic long getGeneration()Returns current generation.
- 
getLastGenerationpublic long getLastGeneration()Returns last succesfully read or written generation.
- 
setInfoStreamIf non-null, information about retries when loading the segments file will be printed to this.
- 
getInfoStreamReturnsinfoStream.- See Also:
 
- 
updateGenerationCarry over generation numbers from another SegmentInfos- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
- 
setNextWriteGenerationpublic void setNextWriteGeneration(long generation) Set the generation to be used for the next commit
- 
filesReturns all file names referenced by SegmentInfo. The returned collection is recomputed on each invocation.- Throws:
- IOException
 
- 
commitWrites and syncs to the Directory dir, taking care to remove the segments file on exceptionNote: changed()should be called prior to this method if changes have been made to thisSegmentInfosinstance- Throws:
- IOException
 
- 
toStringReturns readable description of this segment.
- 
getUserDataReturnuserDatasaved with this commit.- See Also:
 
- 
setUserDataSets the commit data.
- 
totalMaxDocpublic int totalMaxDoc()Returns sum of all segment's maxDocs. Note that this does not include deletions
- 
changedpublic void changed()Call this before committing if changes have been made to the segments.
- 
iteratorReturns an unmodifiableIteratorof contained segments in order.- Specified by:
- iteratorin interface- Iterable<SegmentCommitInfo>
 
- 
asListReturns all contained segments as an unmodifiableListview.
- 
sizepublic int size()Returns number ofSegmentCommitInfos.
- 
addAppends the providedSegmentCommitInfo.
- 
addAllAppends the providedSegmentCommitInfos.
- 
clearpublic void clear()Clear allSegmentCommitInfos.
- 
removeRemove the providedSegmentCommitInfo.WARNING: O(N) cost 
- 
getCommitLuceneVersionReturns which LuceneVersionwrote this commit, or null if the version this index was written with did not directly record the version.
- 
getMinSegmentLuceneVersionReturns the version of the oldest segment, or null if there are no segments.
- 
getIndexCreatedVersionMajorpublic int getIndexCreatedVersionMajor()Return the version major that was used to initially create the index. This version is set when the index is first created and then never changes. This information was added as of version 7.0 so older indices report 6 as a creation version.
 
-