Class NativeUnixDirectory

All Implemented Interfaces:
Closeable, AutoCloseable

public class NativeUnixDirectory extends FSDirectory
A Directory implementation for all Unixes that uses DIRECT I/O to bypass OS level IO caching during merging. For all other cases (searching, writing) we delegate to the provided Directory instance.

See Overview for more details.

To use this you must compile NativePosixUtil.cpp (exposes Linux-specific APIs through JNI) for your platform, by running ant build-native-unix, and then putting the resulting libNativePosixUtil.so (from lucene/build/native) onto your dynamic linker search path.

WARNING: this code is very new and quite easily could contain horrible bugs. For example, here's one known issue: if you use seek in IndexOutput, and then write more than one buffer's worth of bytes, then the file will be wrong. Lucene does not do this today (only writes small number of bytes after seek), but that may change.

This directory passes Solr and Lucene tests on Linux and OS X; other Unixes should work but have not been tested! Use at your own risk.

  • Field Details

    • DEFAULT_MERGE_BUFFER_SIZE

      public static final int DEFAULT_MERGE_BUFFER_SIZE
      Default buffer size before writing to disk (256 KB); larger means less IO load but more RAM and direct buffer storage space consumed during merging.
      See Also:
    • DEFAULT_MIN_BYTES_DIRECT

      public static final long DEFAULT_MIN_BYTES_DIRECT
      Default min expected merge size before direct IO is used (10 MB):
      See Also:
  • Constructor Details

    • NativeUnixDirectory

      public NativeUnixDirectory(File path, int mergeBufferSize, long minBytesDirect, Directory delegate) throws IOException
      Create a new NIOFSDirectory for the named location.
      Parameters:
      path - the path of the directory
      mergeBufferSize - Size of buffer to use for merging. See DEFAULT_MERGE_BUFFER_SIZE.
      minBytesDirect - Merges, or files to be opened for reading, smaller than this will not use direct IO. See DEFAULT_MIN_BYTES_DIRECT
      delegate - fallback Directory for non-merges
      Throws:
      IOException - If there is a low-level I/O error
    • NativeUnixDirectory

      public NativeUnixDirectory(File path, Directory delegate) throws IOException
      Create a new NIOFSDirectory for the named location.
      Parameters:
      path - the path of the directory
      delegate - fallback Directory for non-merges
      Throws:
      IOException - If there is a low-level I/O error
  • Method Details