Skip to content

Commit

Permalink
Fix: deadlock while closing non-shared consumer (apache#1716)
Browse files Browse the repository at this point in the history
  • Loading branch information
Jai Asher authored May 2, 2018
1 parent 1875841 commit 5484585
Showing 1 changed file with 6 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -153,8 +153,12 @@ public synchronized void removeConsumer(Consumer consumer) throws BrokerServiceE
if (!cursor.isDurable()) {
// If cursor is not durable, we need to clean up the subscription as well
close();
topic.removeSubscription(subName);
}

// when topic closes: it iterates through concurrent-subscription map to close each subscription. so,
// topic.remove again try to access same map which creates deadlock. so, execute it in different thread.
topic.getBrokerService().pulsar().getExecutor().submit(() ->{
topic.removeSubscription(subName);
}); }
}

// invalid consumer remove will throw an exception
Expand Down

0 comments on commit 5484585

Please sign in to comment.