From f0914a421fd87671c898e1154d2dcd3ba29acaa4 Mon Sep 17 00:00:00 2001 From: Duo Zhang Date: Sat, 25 Jun 2022 17:05:22 +0800 Subject: [PATCH] HBASE-27160 ClientZKSyncer.deleteDataForClientZkUntilSuccess should break from the loop when deletion is succeeded --- .../hadoop/hbase/master/zksyncer/ClientZKSyncer.java | 6 +++++- .../hbase/client/TestSeparateClientZKCluster.java | 11 +++-------- 2 files changed, 8 insertions(+), 9 deletions(-) diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/master/zksyncer/ClientZKSyncer.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/master/zksyncer/ClientZKSyncer.java index d85cc27dab74..a9881ef9b645 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/master/zksyncer/ClientZKSyncer.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/master/zksyncer/ClientZKSyncer.java @@ -196,12 +196,16 @@ private void deleteDataForClientZkUntilSuccess(String node) throws InterruptedEx LOG.debug("Delete remote " + node + ", client zk wather: " + clientZkWatcher); try { ZKUtil.deleteNode(clientZkWatcher, node); + break; } catch (KeeperException e) { + if (e.code() == KeeperException.Code.NONODE) { + LOG.debug("Node is already deleted, give up", e); + break; + } LOG.debug("Failed to delete node from client ZK, will retry later", e); if (e.code() == KeeperException.Code.SESSIONEXPIRED) { reconnectAfterExpiration(); } - } } } diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestSeparateClientZKCluster.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestSeparateClientZKCluster.java index c1638bf15569..d94fe8e39af5 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestSeparateClientZKCluster.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/client/TestSeparateClientZKCluster.java @@ -133,15 +133,10 @@ public void testMasterSwitch() throws Exception { HMaster master = cluster.getMaster(); master.stopMaster(); LOG.info("Stopped master {}", master.getServerName()); - while (master.isAlive()) { - Thread.sleep(200); - } + TEST_UTIL.waitFor(30000, () -> !master.isAlive()); LOG.info("Shutdown master {}", master.getServerName()); - while (cluster.getMaster() == null || !cluster.getMaster().isInitialized()) { - LOG.info("Get master {}", - cluster.getMaster() == null ? "null" : cluster.getMaster().getServerName()); - Thread.sleep(200); - } + TEST_UTIL.waitFor(30000, + () -> cluster.getMaster() != null && cluster.getMaster().isInitialized()); LOG.info("Got master {}", cluster.getMaster().getServerName()); // confirm client access still works assertTrue(admin.balance(BalanceRequest.defaultInstance()).isBalancerRan());