-
Notifications
You must be signed in to change notification settings - Fork 679
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
SOLR-13350: Multithreaded search #2248
Closed
Closed
Changes from 15 commits
Commits
Show all changes
66 commits
Select commit
Hold shift + click to select a range
3cee3e5
SOLR-13350: Multithreaded search using CollectorManager
74c05e5
SOLR-13350: Fix tests and precommit
976f350
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke 685cd7a
make it compile: ExecutorUtil.newMDCAwareCachedThreadPool signature c…
cpoerschke 8732c33
Update CoreContainer.java - remove unused import
cpoerschke 50160dc
Update CoreContainer.java - queue capacity to continue to match max t…
cpoerschke dbd2d8a
tentative: add indexSearcherExecutorThreads element to solr.xml
cpoerschke 7b5e813
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke 08d415f
git checkout origin/main -- solr/solr-ref-guide/modules/indexing-guide
cpoerschke 3e66068
reduce SolrMultiCollectorManager.[Leaf]Collectors visibility
cpoerschke 85b783e
Merge branch 'main' into jira/solr-13350
cpoerschke 947d841
minor: SolrIndexSearcher style: add couple of finals
cpoerschke c69006a
factor out SolrIndexSearcher.allowMT(Query) utility; add SolrIndexSea…
cpoerschke 366235b
minor: SolrIndexSearcher style: (post main merge) add back couple of …
cpoerschke 1ec21d4
more logic in SolrIndexSearcher.allowMT utility for less code duplica…
cpoerschke a2b48a8
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke 278a1ad
more 'needsScores' use (post origin/main merge conflict resolution)
cpoerschke 2501f7b
tentative: in SolrIndexSearcher.searchCollectorManagers defer scoreMo…
cpoerschke cb3c1cb
undo TestDistributedSearch change by uncommenting commented out code
cpoerschke 119db0f
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke 2201a7d
factor out SolrIndexSearcher.populateScoresIfNeeded method
cpoerschke 4a46b6d
use factored out SolrIndexSearcher.populateScoresIfNeeded method on n…
cpoerschke 43be691
Merge branch 'main' into jira/solr-13350
cpoerschke 65f9a4e
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke ab895b1
factor out SolrMultiCollectorManager.scoreMode method
cpoerschke a59fde7
reduce code duplication w.r.t. populateScoresIfNeeded and populateNex…
cpoerschke 08088d1
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke 5d9ba11
factor out SearchResult.getMaxScore method
cpoerschke 21656ee
factor out SearchResult.getDocSet method
cpoerschke 7219a1e
factor out SearchResult.getTopDocsResult method
cpoerschke 0263958
mark SolrIndexSearcher.SearchResult.result Object[] private
cpoerschke 34c7db0
tentative: replace ThreadSafeBitSet[Collector] with FixedBitSet[Colle…
cpoerschke cc04058
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke fd0d5ab
Revert "tentative: replace ThreadSafeBitSet[Collector] with FixedBitS…
cpoerschke 00a06bc
Revert "Revert "tentative: replace ThreadSafeBitSet[Collector] with F…
cpoerschke 186228d
dev increment: hide FixedBitSetCollector's bit set implementation
cpoerschke 774d60c
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke 14597f9
Merging main into branch
1dc4314
SOLR-13350: Using a RejectedExecutionHandler that submits the tasks b…
d51615e
Refactored MultiThreaded search into a separate class for better read…
noblepaul 9af7c60
Refactored MultiThreaded search into a separate class for better read…
noblepaul 30d6bf2
Merging main to branch
40a66e0
Merging main to branch
ff80c7e
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke bec277a
./gradlew tidy
cpoerschke 842f580
Refactoring multithreaded searcher code into a separate class for bet…
bb80f0d
Removing spurious line
d8b371c
./gradlew tidy again
814b202
refactor
noblepaul 3bb97a5
./gradlew tidy
cpoerschke e8d1efa
add back rawtypes for MultiThreadedSearcher
cpoerschke fdfef9f
(partially) explore segment level FixedBitSet use
cpoerschke 493e284
Revert "(partially) explore segment level FixedBitSet use"
cpoerschke 14b5742
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke b1ac976
basic segment level FixedBitSet use
cpoerschke e169916
Apply suggestions from code review
cpoerschke 35d1383
./gradlew tidy
cpoerschke dd2a7ae
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke f7f96f1
SOLR-13350: Request parameter 'multithreaded' to disable/enable multi…
bdaf7d9
SOLR-13350: Request parameter 'multithreaded' to disable/enable multi…
07f0162
add multiThreaded parameter in QueryCommand
cpoerschke d14329d
Merge remote-tracking branch 'origin/main' into jira/solr-13350
cpoerschke a61b40e
Merging main into branch jira/solr-13350
b86ab72
Merge branch 'main' into jira/solr-13350
e7fb062
SOLR-13350: Defaulting to 4 threads for search
d8e9ef0
SOLR-13350: Defaulting to or 4 for number of threads
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -105,6 +105,8 @@ public class NodeConfig { | |
|
||
private final int replayUpdatesThreads; | ||
|
||
private final int indexSearcherExecutorThreads; | ||
|
||
@Deprecated private final int transientCacheSize; | ||
|
||
private final boolean useSchemaCache; | ||
|
@@ -144,6 +146,7 @@ private NodeConfig( | |
CloudConfig cloudConfig, | ||
Integer coreLoadThreads, | ||
int replayUpdatesThreads, | ||
int indexSearcherExecutorThreads, | ||
int transientCacheSize, | ||
boolean useSchemaCache, | ||
String managementPath, | ||
|
@@ -183,6 +186,7 @@ private NodeConfig( | |
this.cloudConfig = cloudConfig; | ||
this.coreLoadThreads = coreLoadThreads; | ||
this.replayUpdatesThreads = replayUpdatesThreads; | ||
this.indexSearcherExecutorThreads = indexSearcherExecutorThreads; | ||
this.transientCacheSize = transientCacheSize; | ||
this.useSchemaCache = useSchemaCache; | ||
this.managementPath = managementPath; | ||
|
@@ -335,6 +339,10 @@ public int getReplayUpdatesThreads() { | |
return replayUpdatesThreads; | ||
} | ||
|
||
public int getIndexSearcherExecutorThreads() { | ||
return indexSearcherExecutorThreads; | ||
} | ||
|
||
/** | ||
* Returns a directory, optionally a comma separated list of directories that will be added to | ||
* Solr's class path for searching for classes and plugins. The path is either absolute or | ||
|
@@ -597,6 +605,7 @@ public static class NodeConfigBuilder { | |
private CloudConfig cloudConfig; | ||
private int coreLoadThreads = DEFAULT_CORE_LOAD_THREADS; | ||
private int replayUpdatesThreads = Runtime.getRuntime().availableProcessors(); | ||
private int indexSearcherExecutorThreads = DEFAULT_INDEX_SEARCHER_EXECUTOR_THREADS; | ||
@Deprecated private int transientCacheSize = -1; | ||
private boolean useSchemaCache = false; | ||
private String managementPath; | ||
|
@@ -618,6 +627,9 @@ public static class NodeConfigBuilder { | |
// No:of core load threads in cloud mode is set to a default of 8 | ||
public static final int DEFAULT_CORE_LOAD_THREADS_IN_CLOUD = 8; | ||
|
||
public static final int DEFAULT_INDEX_SEARCHER_EXECUTOR_THREADS = | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Should we set it as the as the no:of CPU cores ? |
||
6; // TODO: what should the default be? | ||
|
||
private static final String DEFAULT_CORESLOCATORCLASS = | ||
"org.apache.solr.core.CorePropertiesLocator"; | ||
private static final String DEFAULT_CORESORTERCLASS = "org.apache.solr.core.CoreSorter"; | ||
|
@@ -755,6 +767,11 @@ public NodeConfigBuilder setReplayUpdatesThreads(int replayUpdatesThreads) { | |
return this; | ||
} | ||
|
||
public NodeConfigBuilder setIndexSearcherExecutorThreads(int indexSearcherExecutorThreads) { | ||
this.indexSearcherExecutorThreads = indexSearcherExecutorThreads; | ||
return this; | ||
} | ||
|
||
// Remove in Solr 10.0 | ||
|
||
@Deprecated | ||
|
@@ -904,6 +921,7 @@ public NodeConfig build() { | |
cloudConfig, | ||
coreLoadThreads, | ||
replayUpdatesThreads, | ||
indexSearcherExecutorThreads, | ||
transientCacheSize, | ||
useSchemaCache, | ||
managementPath, | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -46,6 +46,7 @@ public void setDocSet(DocSet set) { | |
docListAndSet = new DocListAndSet(); | ||
} | ||
docListAndSet.docSet = set; | ||
// log.error("set docset {}", docListAndSet.docSet.getBits().length()); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. should remove |
||
} | ||
|
||
public boolean isPartialResults() { | ||
|
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
2/2 Was thinking
IndexSearcherExecutorThreads
name based on https://github.com/apache/lucene/blob/releases/lucene/9.9.2/lucene/core/src/java/org/apache/lucene/search/IndexSearcher.java#L228 signature and specifically no mention of 'collector' in the name since e.g. https://github.com/apache/lucene/blob/releases/lucene/9.9.2/lucene/core/src/java/org/apache/lucene/search/AbstractKnnVectorQuery.java#L82 also uses it.