This is an automated email from the ASF dual-hosted git repository.
technoboy pushed a commit to branch branch-2.11
in repository https://gitbox.apache.org/repos/asf/pulsar.git
The following commit(s) were added to refs/heads/branch-2.11 by this push:
new 2d322d4a7af [fix][meta] deadlock of zkSessionWatcher when zkConnection
loss (#20122)
2d322d4a7af is described below
commit 2d322d4a7af2606828a0a842768fa713a29fe37b
Author: tiny-rain <[email protected]>
AuthorDate: Sun Apr 23 13:45:03 2023 +0800
[fix][meta] deadlock of zkSessionWatcher when zkConnection loss (#20122)
---
.../java/org/apache/pulsar/metadata/impl/ZKSessionWatcher.java | 8 ++++++--
1 file changed, 6 insertions(+), 2 deletions(-)
diff --git
a/pulsar-metadata/src/main/java/org/apache/pulsar/metadata/impl/ZKSessionWatcher.java
b/pulsar-metadata/src/main/java/org/apache/pulsar/metadata/impl/ZKSessionWatcher.java
index a350d4a5b3d..d49c3913262 100644
---
a/pulsar-metadata/src/main/java/org/apache/pulsar/metadata/impl/ZKSessionWatcher.java
+++
b/pulsar-metadata/src/main/java/org/apache/pulsar/metadata/impl/ZKSessionWatcher.java
@@ -80,7 +80,11 @@ public class ZKSessionWatcher implements AutoCloseable,
Watcher {
}
// task that runs every TICK_TIME to check zk connection
- private synchronized void checkConnectionStatus() {
+ // NOT ThreadSafe:
+ // If zk client can't ensure the order, it may lead to problems.
+ // Currently,we only use it in single thread, it will be fine. but we
shouldn't leave any potential problems
+ // in the future.
+ private void checkConnectionStatus() {
try {
CompletableFuture<Watcher.Event.KeeperState> future = new
CompletableFuture<>();
zk.exists("/", false, (StatCallback) (rc, path, ctx, stat) -> {
@@ -125,7 +129,7 @@ public class ZKSessionWatcher implements AutoCloseable,
Watcher {
currentStatus = SessionEvent.SessionLost;
}
- private void checkState(Watcher.Event.KeeperState zkClientState) {
+ private synchronized void checkState(Watcher.Event.KeeperState
zkClientState) {
switch (zkClientState) {
case Expired:
if (currentStatus != SessionEvent.SessionLost) {