-
Notifications
You must be signed in to change notification settings - Fork 1.9k
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
Make MultiBucketConsumerService thread safe to use across slices during search #9047
Conversation
cd45582
to
2bafdef
Compare
Gradle Check (Jenkins) Run Completed with:
|
Compatibility status:
|
Compatibility status:
|
Gradle Check (Jenkins) Run Completed with:
|
server/src/main/java/org/opensearch/search/aggregations/MultiBucketConsumerService.java
Outdated
Show resolved
Hide resolved
server/src/main/java/org/opensearch/search/aggregations/MultiBucketConsumerService.java
Outdated
Show resolved
Hide resolved
server/src/main/java/org/opensearch/search/aggregations/MultiBucketConsumerService.java
Outdated
Show resolved
Hide resolved
server/src/main/java/org/opensearch/search/aggregations/MultiBucketConsumerService.java
Show resolved
Hide resolved
server/src/main/java/org/opensearch/search/aggregations/MultiBucketConsumerService.java
Outdated
Show resolved
Hide resolved
Compatibility status:
|
@neetikasinghal There are some test failures. Can you please check those ? |
Gradle Check (Jenkins) Run Completed with:
|
server/src/main/java/org/opensearch/search/aggregations/MultiBucketConsumerService.java
Show resolved
Hide resolved
Gradle Check (Jenkins) Run Completed with:
|
3d02f73
to
53bfcc2
Compare
@sohami thanks for calling this out. |
Gradle Check (Jenkins) Run Completed with:
|
Codecov Report
@@ Coverage Diff @@
## main #9047 +/- ##
============================================
+ Coverage 71.03% 71.10% +0.07%
+ Complexity 57314 57309 -5
============================================
Files 4765 4765
Lines 270357 270305 -52
Branches 39543 39534 -9
============================================
+ Hits 192043 192199 +156
+ Misses 62151 61966 -185
+ Partials 16163 16140 -23
|
@neetikasinghal Can you please rebase your branch ? |
…ng search Signed-off-by: Neetika Singhal <[email protected]>
53bfcc2
to
4a20a20
Compare
@sohami Done |
Gradle Check (Jenkins) Run Completed with:
|
Known Flaky test: #9034 |
Compatibility status:
|
The backport to
To backport manually, run these commands in your terminal: # Fetch latest updates from GitHub
git fetch
# Create a new working tree
git worktree add ../.worktrees/backport-2.x 2.x
# Navigate to the new working tree
pushd ../.worktrees/backport-2.x
# Create a new branch
git switch --create backport/backport-9047-to-2.x
# Cherry-pick the merged commit of this pull request and resolve the conflicts
git cherry-pick -x --mainline 1 24595c9fbace3516e886137058f3a8b992937652
# Push it to GitHub
git push --set-upstream origin backport/backport-9047-to-2.x
# Go back to the original working tree
popd
# Delete the working tree
git worktree remove ../.worktrees/backport-2.x Then, create a pull request where the |
@neetikasinghal Backport failed. Can you please do it manually |
…ng search (opensearch-project#9047) Signed-off-by: Neetika Singhal <[email protected]> (cherry picked from commit 24595c9)
…ng search (opensearch-project#9047) Signed-off-by: Neetika Singhal <[email protected]> (cherry picked from commit 24595c9)
…ng search (opensearch-project#9047) Signed-off-by: Neetika Singhal <[email protected]>
…ng search (#9047) (#9110) Signed-off-by: Neetika Singhal <[email protected]>
…ng search (opensearch-project#9047) Signed-off-by: Neetika Singhal <[email protected]> Signed-off-by: Kaushal Kumar <[email protected]>
…ng search (opensearch-project#9047) Signed-off-by: Neetika Singhal <[email protected]> Signed-off-by: Ivan Brusic <[email protected]>
…ng search (opensearch-project#9047) Signed-off-by: Neetika Singhal <[email protected]> Signed-off-by: Shivansh Arora <[email protected]>
Description
callCount variable needs to be made thread safe as there is a periodic check on the CircuitBreaker in the MultiConsumerService that checks if the CB has tripped. With Concurrent Search, for each shard, there are multiple slices running on different threads and having one instance of MultiBucketConsumer. Multiple threads within the same instance of MultiBucketConsumer will try to access the callCount variable, and as of current logic that checks for CB trip after every 1024 calls to the accept function, there is possibility that if the callCount is not made thread safe, the CB trip check might never happen.
Initializing callCount as a LongAdder variable making it thread safe and also having an additional volatile` variable that tries to trip the CB for the other threads in case for one of the threads CB has already tripped.
Related Issues
Resolves #7785
Check List
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.
For more information on following Developer Certificate of Origin and signing off your commits, please check here.