LUCENE-1365: deprecate addIndexes(Directory[]) in favor of addIndexesNoOptimize

git-svn-id: https://svn.apache.org/repos/asf/lucene/java/trunk@688315 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Michael McCandless 2008-08-23 13:32:05 +00:00
parent 003a853cc8
commit 59b8dca69a
1 changed files with 34 additions and 65 deletions

View File

@ -2748,58 +2748,9 @@ public class IndexWriter {
} }
/** Merges all segments from an array of indexes into this index. /** Merges all segments from an array of indexes into this index.
* * @deprecated Use {@link #addIndexesNoOptimize} instead,
* <p>This may be used to parallelize batch indexing. A large document * then separately call {@link #optimize} afterwards if
* collection can be broken into sub-collections. Each sub-collection can be * you need to.
* indexed in parallel, on a different thread, process or machine. The
* complete index can then be created by merging sub-collection indexes
* with this method.
*
* <p><b>NOTE:</b> the index in each Directory must not be
* changed (opened by a writer) while this method is
* running. This method does not acquire a write lock in
* each input Directory, so it is up to the caller to
* enforce this.
*
* <p><b>NOTE:</b> while this is running, any attempts to
* add or delete documents (with another thread) will be
* paused until this method completes.
*
* <p>After this completes, the index is optimized.
*
* <p>This method is transactional in how Exceptions are
* handled: it does not commit a new segments_N file until
* all indexes are added. This means if an Exception
* occurs (for example disk full), then either no indexes
* will have been added or they all will have been.</p>
*
* <p>If an Exception is hit, it's still possible that all
* indexes were successfully added. This happens when the
* Exception is hit when trying to build a CFS file. In
* this case, one segment in the index will be in non-CFS
* format, even when using compound file format.</p>
*
* <p>Also note that on an Exception, the index may still
* have been partially or fully optimized even though none
* of the input indexes were added. </p>
*
* <p>Note that this requires temporary free space in the
* Directory up to 2X the sum of all input indexes
* (including the starting index). If readers/searchers
* are open against the starting index, then temporary
* free space required will be higher by the size of the
* starting index (see {@link #optimize()} for details).
* </p>
*
* <p>Once this completes, the final size of the index
* will be less than the sum of all input index sizes
* (including the starting index). It could be quite a
* bit smaller (if there were many pending deletes) or
* just slightly smaller.</p>
*
* <p>See <a target="_top"
* href="http://issues.apache.org/jira/browse/LUCENE-702">LUCENE-702</a>
* for details.</p>
* @throws CorruptIndexException if the index is corrupt * @throws CorruptIndexException if the index is corrupt
* @throws IOException if there is a low-level IO error * @throws IOException if there is a low-level IO error
*/ */
@ -2863,11 +2814,14 @@ public class IndexWriter {
} }
/** /**
* Merges all segments from an array of indexes into this index. * Merges all segments from an array of indexes into this
* <p> * index.
* This is similar to addIndexes(Directory[]). However, no optimize() *
* is called either at the beginning or at the end. Instead, merges * <p>This may be used to parallelize batch indexing. A large document
* are carried out as necessary. * collection can be broken into sub-collections. Each sub-collection can be
* indexed in parallel, on a different thread, process or machine. The
* complete index can then be created by merging sub-collection indexes
* with this method.
* *
* <p><b>NOTE:</b> the index in each Directory must not be * <p><b>NOTE:</b> the index in each Directory must not be
* changed (opened by a writer) while this method is * changed (opened by a writer) while this method is
@ -2879,14 +2833,29 @@ public class IndexWriter {
* add or delete documents (with another thread) will be * add or delete documents (with another thread) will be
* paused until this method completes. * paused until this method completes.
* *
* <p> * <p>This method is transactional in how Exceptions are
* This requires this index not be among those to be added, and the * handled: it does not commit a new segments_N file until
* upper bound* of those segment doc counts not exceed maxMergeDocs. * all indexes are added. This means if an Exception
* occurs (for example disk full), then either no indexes
* will have been added or they all will have been.</p>
*
* <p>Note that this requires temporary free space in the
* Directory up to 2X the sum of all input indexes
* (including the starting index). If readers/searchers
* are open against the starting index, then temporary
* free space required will be higher by the size of the
* starting index (see {@link #optimize()} for details).
* </p>
*
* <p>Once this completes, the final size of the index
* will be less than the sum of all input index sizes
* (including the starting index). It could be quite a
* bit smaller (if there were many pending deletes) or
* just slightly smaller.</p>
*
* <p>
* This requires this index not be among those to be added.
* *
* <p>See {@link #addIndexes(Directory[])} for
* details on transactional semantics, temporary free
* space required in the Directory, and non-CFS segments
* on an Exception.</p>
* @throws CorruptIndexException if the index is corrupt * @throws CorruptIndexException if the index is corrupt
* @throws IOException if there is a low-level IO error * @throws IOException if there is a low-level IO error
*/ */
@ -3019,7 +2988,7 @@ public class IndexWriter {
* add or delete documents (with another thread) will be * add or delete documents (with another thread) will be
* paused until this method completes. * paused until this method completes.
* *
* <p>See {@link #addIndexes(Directory[])} for * <p>See {@link #addIndexesNoOptimize(Directory[])} for
* details on transactional semantics, temporary free * details on transactional semantics, temporary free
* space required in the Directory, and non-CFS segments * space required in the Directory, and non-CFS segments
* on an Exception.</p> * on an Exception.</p>