Lucy::Index::IndexManager - Policies governing index updating, locking, and file deletion.
use Sys::Hostname qw( hostname ); my $hostname = hostname() or die "Can't get unique hostname"; my $manager = Lucy::Index::IndexManager->new( host => $hostname, ); # Index time: my $indexer = Lucy::Index::Indexer->new( index => '/path/to/index', manager => $manager, ); # Search time: my $reader = Lucy::Index::IndexReader->open( index => '/path/to/index', manager => $manager, ); my $searcher = Lucy::Search::IndexSearcher->new( index => $reader );
IndexManager is an advanced-use class for controlling index locking, updating, merging, and deletion behaviors.
IndexManager and Architecture are complementary classes: Architecture is used to define traits and behaviors which cannot change for the life of an index; IndexManager is used for defining rules which may change from process to process.
my $manager = Lucy::Index::IndexManager->new( host => $hostname, # default: "" );
Create the Lock which controls access to modifying the logical content of the index.
Return an array of SegReaders representing segments that should be consolidated. Implementations must balance index-time churn against search-time degradation due to segment proliferation. The default implementation prefers small segments or segments with a high proportion of deletions.
folder member. Typical clients (Indexer, IndexReader) will use this method to install their own Folder instance.
Setter for write lock timeout. Default: 1000 milliseconds.
Getter for write lock timeout.
Setter for write lock retry interval. Default: 100 milliseconds.
Getter for write lock retry interval.
Lucy::Index::IndexManager isa Clownfish::Obj.