This repository has been archived by the owner on Jan 24, 2024. It is now read-only.
Fix deadlock caused by KafkaTopicConsumerManager #620
Merged
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.
Fixes #618
Motivation
See #618 (comment) for the deadlock analysis.
Modifications
ConcurrentHashMap
instead ofConcurrentLongHashMap
. Though this bug may already be fixed in Ensure read-lock is not continuously held on a section while iterating over concurrent maps apache/pulsar#9787, theConcurrentHashMap
from Java standard library is more reliable. The possible performance enhancement brought byConcurrentLongHashMap
still needs to be proved.AtomicBoolean
asKafkaTopicConsumerManager
's state instead of read-write lock to avoidclose()
method that tries to acquire write lock blocking.consumerTopicManagers
to a static field, there's no reason to run a task for each connection.