[improve][ml] Avoid repetitive nested lock for isMessageDeleted in ManagedCursorImpl#23609
Merged
lhotari merged 1 commit intoapache:masterfrom Nov 19, 2024
Merged
Conversation
Contributor
Author
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #23609 +/- ##
============================================
+ Coverage 73.57% 74.38% +0.80%
- Complexity 32624 34458 +1834
============================================
Files 1877 1944 +67
Lines 139502 147128 +7626
Branches 15299 16224 +925
============================================
+ Hits 102638 109437 +6799
- Misses 28908 29264 +356
- Partials 7956 8427 +471
Flags with carried forward coverage won't be shown. Click here to find out more.
|
2 tasks
nikhil-ctds
pushed a commit
to datastax/pulsar
that referenced
this pull request
Nov 26, 2024
…nagedCursorImpl (apache#23609) (cherry picked from commit 895e968) (cherry picked from commit 96cf000)
srinath-ctds
pushed a commit
to datastax/pulsar
that referenced
this pull request
Nov 26, 2024
…nagedCursorImpl (apache#23609) (cherry picked from commit 895e968) (cherry picked from commit 96cf000)
hanmz
pushed a commit
to hanmz/pulsar
that referenced
this pull request
Feb 12, 2025
This file contains hidden or 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
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
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.
Main Issue: #23605
Motivation
The following are all related to the
org.apache.bookkeeper.mledger.impl.ManagedCursorImpl#isMessageDeleted:pulsar/managed-ledger/src/main/java/org/apache/bookkeeper/mledger/impl/ManagedCursorImpl.java
Lines 3542 to 3551 in 89ccb73
A write lock has already been acquired, but a read lock has been acquired as well. This doesn't pose a major problem, but it does result in some unnecessary additional overhead.
pulsar/managed-ledger/src/main/java/org/apache/bookkeeper/mledger/impl/ManagedCursorImpl.java
Lines 2328 to 2348 in 89ccb73
The performance impact of nested read locks can be negligible, but frequent acquisition and release of locks will slightly increase system overhead.
pulsar/managed-ledger/src/main/java/org/apache/bookkeeper/mledger/impl/ManagedCursorImpl.java
Lines 1570 to 1575 in 89ccb73
Modifications
Verifying this change
(Please pick either of the following options)
This change is a trivial rework / code cleanup without any test coverage.
(or)
This change is already covered by existing tests, such as (please describe tests).
(or)
This change added tests and can be verified as follows:
(example:)
Does this pull request potentially affect one of the following parts:
If the box was checked, please highlight the changes
Documentation
docdoc-requireddoc-not-neededdoc-completeMatching PR in forked repository
PR in forked repository: