From fa7d5cacd64fe56165b9d0f17a3985b286d730c1 Mon Sep 17 00:00:00 2001 From: Sorabh Hamirwasia Date: Tue, 15 Aug 2023 23:46:54 -0700 Subject: [PATCH] Disable concurrent segment search for timeseries index and with sort query Signed-off-by: Sorabh Hamirwasia --- .../org/opensearch/search/DefaultSearchContext.java | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/server/src/main/java/org/opensearch/search/DefaultSearchContext.java b/server/src/main/java/org/opensearch/search/DefaultSearchContext.java index f64c17e873596..5799d3d643140 100644 --- a/server/src/main/java/org/opensearch/search/DefaultSearchContext.java +++ b/server/src/main/java/org/opensearch/search/DefaultSearchContext.java @@ -925,11 +925,20 @@ public BucketCollectorProcessor bucketCollectorProcessor() { } /** - * Evaluate based on cluster and index settings if concurrent segment search should be used for this request context + * Checks if concurrent segment search should not be used for certain request type. Otherwise, evaluates based on cluster and index + * settings if concurrent segment search should be used for this request context. * @return true: use concurrent search * false: otherwise */ private boolean useConcurrentSearch(Executor concurrentSearchExecutor) { + // Disable concurrent segment search if time-series based sort optimization can be applied on the index. This is done to avoid + // performance regression in such cases as segment order matters and most of the segments are skipped and not even evaluated for + // search. When concurrent segment search is used then order of the segments will be randomized and segments gets distributed across + // slices and unnecessary work will be done + if (indexShard.isTimeSeriesDescSortOptimizationEnabled()) { + return false; + } + if (FeatureFlags.isEnabled(FeatureFlags.CONCURRENT_SEGMENT_SEARCH) && (clusterService != null) && (concurrentSearchExecutor != null)) {