Class ByteBuffersDirectory
- All Implemented Interfaces:
Closeable,AutoCloseable
ByteBuffer-based Directory implementation that can be used to store index files
on the heap.
Important: Note that MMapDirectory is nearly always a better choice as it uses OS
caches more effectively (through memory-mapped buffers). A heap-based directory like this one can
have the advantage in case of ephemeral, small, short-lived indexes when disk syncs provide an
additional overhead.
- WARNING: This API is experimental and might change in incompatible ways in the next release.
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final BiFunction<String, ByteBuffersDataOutput, IndexInput> static final BiFunction<String, ByteBuffersDataOutput, IndexInput> static final BiFunction<String, ByteBuffersDataOutput, IndexInput> Fields inherited from class org.apache.lucene.store.BaseDirectory
isOpen, lockFactory -
Constructor Summary
ConstructorsConstructorDescriptionByteBuffersDirectory(LockFactory lockFactory) ByteBuffersDirectory(LockFactory factory, Supplier<ByteBuffersDataOutput> bbOutputSupplier, BiFunction<String, ByteBuffersDataOutput, IndexInput> outputToInput) -
Method Summary
Modifier and TypeMethodDescriptionvoidclose()Closes the directory.createOutput(String name, IOContext context) Creates a new, empty file in the directory and returns anIndexOutputinstance for appending data to this file.createTempOutput(String prefix, String suffix, IOContext context) Creates a new, empty, temporary file in the directory and returns anIndexOutputinstance for appending data to this file.voiddeleteFile(String name) Removes an existing file in the directory.booleanfileExists(String name) longfileLength(String name) Returns the byte length of a file in the directory.Returns a set of files currently pending deletion in this directory.String[]listAll()Returns names of all files stored in this directory.Opens a stream for reading an existing file.voidRenamessourcefile todestfile wheredestmust not already exist in the directory.voidsync(Collection<String> names) Ensures that any writes to these files are moved to stable storage (made durable).voidEnsures that directory metadata, such as recent file renames, are moved to stable storage.Methods inherited from class org.apache.lucene.store.BaseDirectory
ensureOpen, obtainLock, toStringMethods inherited from class org.apache.lucene.store.Directory
copyFrom, getTempFileName, openChecksumInput
-
Field Details
-
OUTPUT_AS_MANY_BUFFERS
-
OUTPUT_AS_ONE_BUFFER
-
OUTPUT_AS_BYTE_ARRAY
-
-
Constructor Details
-
ByteBuffersDirectory
public ByteBuffersDirectory() -
ByteBuffersDirectory
-
ByteBuffersDirectory
public ByteBuffersDirectory(LockFactory factory, Supplier<ByteBuffersDataOutput> bbOutputSupplier, BiFunction<String, ByteBuffersDataOutput, IndexInput> outputToInput)
-
-
Method Details
-
listAll
Description copied from class:DirectoryReturns names of all files stored in this directory. The output must be in sorted (UTF-16, java'sString.compareTo(java.lang.String)) order.- Specified by:
listAllin classDirectory- Throws:
IOException- in case of I/O error
-
deleteFile
Description copied from class:DirectoryRemoves an existing file in the directory.This method must throw either
NoSuchFileExceptionorFileNotFoundExceptionifnamepoints to a non-existing file.- Specified by:
deleteFilein classDirectory- Parameters:
name- the name of an existing file.- Throws:
IOException- in case of I/O error
-
fileLength
Description copied from class:DirectoryReturns the byte length of a file in the directory.This method must throw either
NoSuchFileExceptionorFileNotFoundExceptionifnamepoints to a non-existing file.- Specified by:
fileLengthin classDirectory- Parameters:
name- the name of an existing file.- Throws:
IOException- in case of I/O error
-
fileExists
-
createOutput
Description copied from class:DirectoryCreates a new, empty file in the directory and returns anIndexOutputinstance for appending data to this file.This method must throw
FileAlreadyExistsExceptionif the file already exists.- Specified by:
createOutputin classDirectory- Parameters:
name- the name of the file to create.- Throws:
IOException- in case of I/O error
-
createTempOutput
public IndexOutput createTempOutput(String prefix, String suffix, IOContext context) throws IOException Description copied from class:DirectoryCreates a new, empty, temporary file in the directory and returns anIndexOutputinstance for appending data to this file.The temporary file name (accessible via
IndexOutput.getName()) will start withprefix, end withsuffixand have a reserved file extension.tmp.- Specified by:
createTempOutputin classDirectory- Throws:
IOException
-
rename
Description copied from class:DirectoryRenamessourcefile todestfile wheredestmust not already exist in the directory.It is permitted for this operation to not be truly atomic, for example both
sourceanddestcan be visible temporarily inDirectory.listAll(). However, the implementation of this method must ensure the content ofdestappears as the entiresourceatomically. So oncedestis visible for readers, the entire content of previoussourceis visible.This method is used by IndexWriter to publish commits.
- Specified by:
renamein classDirectory- Throws:
IOException
-
sync
Description copied from class:DirectoryEnsures that any writes to these files are moved to stable storage (made durable).Lucene uses this to properly commit changes to the index, to prevent a machine/OS crash from corrupting the index.
- Specified by:
syncin classDirectory- Throws:
IOException- See Also:
-
syncMetaData
Description copied from class:DirectoryEnsures that directory metadata, such as recent file renames, are moved to stable storage.- Specified by:
syncMetaDatain classDirectory- Throws:
IOException- See Also:
-
openInput
Description copied from class:DirectoryOpens a stream for reading an existing file.This method must throw either
NoSuchFileExceptionorFileNotFoundExceptionifnamepoints to a non-existing file.- Specified by:
openInputin classDirectory- Parameters:
name- the name of an existing file.- Throws:
IOException- in case of I/O error
-
close
Description copied from class:DirectoryCloses the directory.- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Specified by:
closein classDirectory- Throws:
IOException
-
getPendingDeletions
Description copied from class:DirectoryReturns a set of files currently pending deletion in this directory.- Specified by:
getPendingDeletionsin classDirectory
-