From 9c2a21ce29d190718446f03a4e77df6d1089f1c5 Mon Sep 17 00:00:00 2001 From: Michael McCandless Date: Sun, 19 Jun 2011 10:15:32 +0000 Subject: [PATCH] LUCENE-3197: must also count the segment being produced by an in-flight merge as original (as of when optimize starts) to ensure all deletions against that segment are also merged away git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1137330 13f79535-47bb-0310-9956-ffa450edef68 --- .../src/java/org/apache/lucene/index/PKIndexSplitter.java | 1 + lucene/src/java/org/apache/lucene/index/IndexWriter.java | 7 +++++-- .../src/java/org/apache/lucene/index/LogMergePolicy.java | 6 +++--- 3 files changed, 9 insertions(+), 5 deletions(-) diff --git a/lucene/contrib/misc/src/java/org/apache/lucene/index/PKIndexSplitter.java b/lucene/contrib/misc/src/java/org/apache/lucene/index/PKIndexSplitter.java index 398d99ddb7f..0ecc5fb784e 100644 --- a/lucene/contrib/misc/src/java/org/apache/lucene/index/PKIndexSplitter.java +++ b/lucene/contrib/misc/src/java/org/apache/lucene/index/PKIndexSplitter.java @@ -34,6 +34,7 @@ import org.apache.lucene.util.Version; /** * Split an index based on a {@link Filter}. */ + public class PKIndexSplitter { private final Filter docsInFirstIndex; private final Directory input; diff --git a/lucene/src/java/org/apache/lucene/index/IndexWriter.java b/lucene/src/java/org/apache/lucene/index/IndexWriter.java index ce421ca68dd..8817c7601bd 100644 --- a/lucene/src/java/org/apache/lucene/index/IndexWriter.java +++ b/lucene/src/java/org/apache/lucene/index/IndexWriter.java @@ -1674,11 +1674,13 @@ public class IndexWriter implements Closeable, TwoPhaseCommit { for(final MergePolicy.OneMerge merge : pendingMerges) { merge.optimize = true; merge.maxNumSegmentsOptimize = maxNumSegments; + segmentsToOptimize.put(merge.info, Boolean.TRUE); } for ( final MergePolicy.OneMerge merge: runningMerges ) { merge.optimize = true; merge.maxNumSegmentsOptimize = maxNumSegments; + segmentsToOptimize.put(merge.info, Boolean.TRUE); } } @@ -1891,7 +1893,6 @@ public class IndexWriter implements Closeable, TwoPhaseCommit { final MergePolicy.MergeSpecification spec; if (optimize) { spec = mergePolicy.findMergesForOptimize(segmentInfos, maxNumSegmentsOptimize, Collections.unmodifiableMap(segmentsToOptimize)); - if (spec != null) { final int numMerges = spec.merges.size(); for(int i=0;i segments = infos.asList(); - + // First, enroll all "full" merges (size // mergeFactor) to potentially be run concurrently: while (last - maxNumSegments + 1 >= mergeFactor) { @@ -353,7 +353,7 @@ public abstract class LogMergePolicy extends MergePolicy { assert maxNumSegments > 0; if (verbose()) { - message("findMergesForOptimize: maxNumSegs=" + maxNumSegments + " segsToOptimize= "+ segmentsToOptimize); + message("findMergesForOptimize: maxNumSegs=" + maxNumSegments + " segsToOptimize="+ segmentsToOptimize); } // If the segments are already optimized (e.g. there's only 1 segment), or @@ -401,7 +401,7 @@ public abstract class LogMergePolicy extends MergePolicy { break; } } - + if (anyTooLarge) { return findMergesForOptimizeSizeLimit(infos, maxNumSegments, last); } else {