Side-step pending deletes check (#30571)

When we split/shrink an index we open several IndexWriter instances
causeing file-deletes to be pending on windows. This subsequently fails
when we open an IW to bootstrap the index history due to pending deletes.
This change sidesteps the check since we know our history goes forward
in terms of files and segments.

Closes #30416
This commit is contained in:
Simon Willnauer 2018-05-15 11:51:54 +02:00 committed by GitHub
parent 098b3b7fb4
commit b50cf3c6b0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 17 additions and 16 deletions

View File

@ -107,11 +107,8 @@ setup:
--- ---
"Split from 1 to N": "Split from 1 to N":
- skip: - skip:
# when re-enabling uncomment the below skips version: " - 6.99.99"
version: "all" reason: Automatic preparation for splitting was added in 7.0.0
reason: "AwaitsFix'ing, see https://github.com/elastic/elasticsearch/issues/30503"
# version: " - 6.3.99"
# reason: expects warnings that pre-6.4.0 will not send
features: "warnings" features: "warnings"
- do: - do:
indices.create: indices.create:

View File

@ -1,11 +1,8 @@
--- ---
"Split index ignores target template mapping": "Split index ignores target template mapping":
- skip: - skip:
# when re-enabling uncomment the below skips version: " - 6.3.99"
version: "all" reason: expects warnings that pre-6.4.0 will not send
reason: "AwaitsFix'ing, see https://github.com/elastic/elasticsearch/issues/30503"
# version: " - 6.3.99"
# reason: expects warnings that pre-6.4.0 will not send
features: "warnings" features: "warnings"
# create index # create index

View File

@ -731,13 +731,13 @@ public class Store extends AbstractIndexShardComponent implements Closeable, Ref
private final Logger deletesLogger; private final Logger deletesLogger;
StoreDirectory(Directory delegateDirectory, Logger deletesLogger) throws IOException { StoreDirectory(Directory delegateDirectory, Logger deletesLogger) {
super(delegateDirectory); super(delegateDirectory);
this.deletesLogger = deletesLogger; this.deletesLogger = deletesLogger;
} }
@Override @Override
public void close() throws IOException { public void close() {
assert false : "Nobody should close this directory except of the Store itself"; assert false : "Nobody should close this directory except of the Store itself";
} }
@ -759,6 +759,17 @@ public class Store extends AbstractIndexShardComponent implements Closeable, Ref
public String toString() { public String toString() {
return "store(" + in.toString() + ")"; return "store(" + in.toString() + ")";
} }
@Override
public boolean checkPendingDeletions() throws IOException {
if (super.checkPendingDeletions()) {
deletesLogger.warn("directory has still pending deletes");
}
// we skip this check since our IW usage always goes forward.
// we still might run into situations where we have pending deletes ie. in shrink / split case
// and that will cause issues on windows since we open multiple IW instance one after another during the split/shrink recovery
return false;
}
} }
/** /**

View File

@ -23,7 +23,6 @@ import org.apache.lucene.search.Sort;
import org.apache.lucene.search.SortField; import org.apache.lucene.search.SortField;
import org.apache.lucene.search.SortedSetSelector; import org.apache.lucene.search.SortedSetSelector;
import org.apache.lucene.search.SortedSetSortField; import org.apache.lucene.search.SortedSetSortField;
import org.apache.lucene.util.LuceneTestCase.AwaitsFix;
import org.elasticsearch.Version; import org.elasticsearch.Version;
import org.elasticsearch.action.admin.cluster.reroute.ClusterRerouteResponse; import org.elasticsearch.action.admin.cluster.reroute.ClusterRerouteResponse;
import org.elasticsearch.action.admin.cluster.state.ClusterStateRequest; import org.elasticsearch.action.admin.cluster.state.ClusterStateRequest;
@ -77,7 +76,6 @@ import static org.hamcrest.Matchers.containsString;
import static org.hamcrest.Matchers.equalTo; import static org.hamcrest.Matchers.equalTo;
import static org.hamcrest.Matchers.greaterThanOrEqualTo; import static org.hamcrest.Matchers.greaterThanOrEqualTo;
@AwaitsFix(bugUrl = "https://github.com/elastic/elasticsearch/issues/30416")
public class ShrinkIndexIT extends ESIntegTestCase { public class ShrinkIndexIT extends ESIntegTestCase {
@Override @Override

View File

@ -24,7 +24,6 @@ import org.apache.lucene.search.SortField;
import org.apache.lucene.search.SortedSetSelector; import org.apache.lucene.search.SortedSetSelector;
import org.apache.lucene.search.SortedSetSortField; import org.apache.lucene.search.SortedSetSortField;
import org.apache.lucene.search.join.ScoreMode; import org.apache.lucene.search.join.ScoreMode;
import org.apache.lucene.util.LuceneTestCase;
import org.elasticsearch.Version; import org.elasticsearch.Version;
import org.elasticsearch.action.admin.cluster.state.ClusterStateRequest; import org.elasticsearch.action.admin.cluster.state.ClusterStateRequest;
import org.elasticsearch.action.admin.cluster.state.ClusterStateResponse; import org.elasticsearch.action.admin.cluster.state.ClusterStateResponse;
@ -81,7 +80,6 @@ import static org.hamcrest.Matchers.equalTo;
import static org.hamcrest.Matchers.greaterThanOrEqualTo; import static org.hamcrest.Matchers.greaterThanOrEqualTo;
@LuceneTestCase.AwaitsFix(bugUrl = "https://github.com/elastic/elasticsearch/issues/30416")
public class SplitIndexIT extends ESIntegTestCase { public class SplitIndexIT extends ESIntegTestCase {
@Override @Override