Fix searchafter high latency when after value is out of range for segment (#12334)

This commit is contained in:
Chaitanya Gohel 2023-05-31 22:07:53 +00:00 committed by GitHub
parent da36c24cb9
commit d44be24025
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 15 additions and 11 deletions

View File

@ -91,8 +91,8 @@ public abstract class NumericComparator<T extends Number> extends FieldComparato
// if skipping functionality should be enabled on this segment // if skipping functionality should be enabled on this segment
private final boolean enableSkipping; private final boolean enableSkipping;
private final int maxDoc; private final int maxDoc;
private final byte[] minValueAsBytes; private byte[] minValueAsBytes;
private final byte[] maxValueAsBytes; private byte[] maxValueAsBytes;
private DocIdSetIterator competitiveIterator; private DocIdSetIterator competitiveIterator;
private long iteratorCost = -1; private long iteratorCost = -1;
@ -128,16 +128,10 @@ public abstract class NumericComparator<T extends Number> extends FieldComparato
} }
this.enableSkipping = true; // skipping is enabled when points are available this.enableSkipping = true; // skipping is enabled when points are available
this.maxDoc = context.reader().maxDoc(); this.maxDoc = context.reader().maxDoc();
this.maxValueAsBytes =
reverse == false ? new byte[bytesCount] : topValueSet ? new byte[bytesCount] : null;
this.minValueAsBytes =
reverse ? new byte[bytesCount] : topValueSet ? new byte[bytesCount] : null;
this.competitiveIterator = DocIdSetIterator.all(maxDoc); this.competitiveIterator = DocIdSetIterator.all(maxDoc);
} else { } else {
this.enableSkipping = false; this.enableSkipping = false;
this.maxDoc = 0; this.maxDoc = 0;
this.maxValueAsBytes = null;
this.minValueAsBytes = null;
} }
} }
@ -191,7 +185,9 @@ public abstract class NumericComparator<T extends Number> extends FieldComparato
// update its iterator to include possibly only docs that are "stronger" than the current bottom // update its iterator to include possibly only docs that are "stronger" than the current bottom
// entry // entry
private void updateCompetitiveIterator() throws IOException { private void updateCompetitiveIterator() throws IOException {
if (enableSkipping == false || hitsThresholdReached == false || queueFull == false) return; if (enableSkipping == false
|| hitsThresholdReached == false
|| (queueFull == false && topValueSet == false)) return;
// if some documents have missing points, check that missing values prohibits optimization // if some documents have missing points, check that missing values prohibits optimization
if ((pointValues.getDocCount() < maxDoc) && isMissingValueCompetitive()) { if ((pointValues.getDocCount() < maxDoc) && isMissingValueCompetitive()) {
return; // we can't filter out documents, as documents with missing values are competitive return; // we can't filter out documents, as documents with missing values are competitive
@ -204,13 +200,21 @@ public abstract class NumericComparator<T extends Number> extends FieldComparato
return; return;
} }
if (reverse == false) { if (reverse == false) {
encodeBottom(maxValueAsBytes); if (queueFull) { // bottom is avilable only when queue is full
maxValueAsBytes = maxValueAsBytes == null ? new byte[bytesCount] : maxValueAsBytes;
encodeBottom(maxValueAsBytes);
}
if (topValueSet) { if (topValueSet) {
minValueAsBytes = minValueAsBytes == null ? new byte[bytesCount] : minValueAsBytes;
encodeTop(minValueAsBytes); encodeTop(minValueAsBytes);
} }
} else { } else {
encodeBottom(minValueAsBytes); if (queueFull) { // bottom is avilable only when queue is full
minValueAsBytes = minValueAsBytes == null ? new byte[bytesCount] : minValueAsBytes;
encodeBottom(minValueAsBytes);
}
if (topValueSet) { if (topValueSet) {
maxValueAsBytes = maxValueAsBytes == null ? new byte[bytesCount] : maxValueAsBytes;
encodeTop(maxValueAsBytes); encodeTop(maxValueAsBytes);
} }
} }