Ensure not to open directory reader on transport thread (#55419)
This change adds an assertion making sure that we won't accidentally open directory readers using transport threads.
This commit is contained in:
parent
a1ec45e7e6
commit
9e3b813b62
|
@ -41,6 +41,7 @@ import org.elasticsearch.index.translog.TranslogConfig;
|
||||||
import org.elasticsearch.index.translog.TranslogDeletionPolicy;
|
import org.elasticsearch.index.translog.TranslogDeletionPolicy;
|
||||||
import org.elasticsearch.index.translog.TranslogStats;
|
import org.elasticsearch.index.translog.TranslogStats;
|
||||||
import org.elasticsearch.search.suggest.completion.CompletionStats;
|
import org.elasticsearch.search.suggest.completion.CompletionStats;
|
||||||
|
import org.elasticsearch.transport.Transports;
|
||||||
|
|
||||||
import java.io.Closeable;
|
import java.io.Closeable;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -178,6 +179,7 @@ public class ReadOnlyEngine extends Engine {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected DirectoryReader open(IndexCommit commit) throws IOException {
|
protected DirectoryReader open(IndexCommit commit) throws IOException {
|
||||||
|
assert Transports.assertNotTransportThread("opening index commit of a read-only engine");
|
||||||
return DirectoryReader.open(commit, OFF_HEAP_READER_ATTRIBUTES);
|
return DirectoryReader.open(commit, OFF_HEAP_READER_ATTRIBUTES);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -514,6 +516,7 @@ public class ReadOnlyEngine extends Engine {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static DirectoryReader openDirectory(Directory directory, boolean wrapSoftDeletes) throws IOException {
|
protected static DirectoryReader openDirectory(Directory directory, boolean wrapSoftDeletes) throws IOException {
|
||||||
|
assert Transports.assertNotTransportThread("opening directory reader of a read-only engine");
|
||||||
final DirectoryReader reader = DirectoryReader.open(directory, OFF_HEAP_READER_ATTRIBUTES);
|
final DirectoryReader reader = DirectoryReader.open(directory, OFF_HEAP_READER_ATTRIBUTES);
|
||||||
if (wrapSoftDeletes) {
|
if (wrapSoftDeletes) {
|
||||||
return new SoftDeletesDirectoryReaderWrapper(reader, Lucene.SOFT_DELETES_FIELD);
|
return new SoftDeletesDirectoryReaderWrapper(reader, Lucene.SOFT_DELETES_FIELD);
|
||||||
|
|
Loading…
Reference in New Issue