From ad146957e385878dd6f3620b2b52054d44a72ef0 Mon Sep 17 00:00:00 2001 From: Dave Marion Date: Thu, 16 Jan 2025 16:15:32 +0000 Subject: [PATCH] Remove ZooCache from ListInstances command ServiceLock.getData uses either a ZooCache or ZooKeeper instance. Changed the utility to use a ZooKeeper instance. Closes #5257 --- .../accumulo/server/util/ListInstances.java | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/server/base/src/main/java/org/apache/accumulo/server/util/ListInstances.java b/server/base/src/main/java/org/apache/accumulo/server/util/ListInstances.java index 131ded3d576..ee4a0302b75 100644 --- a/server/base/src/main/java/org/apache/accumulo/server/util/ListInstances.java +++ b/server/base/src/main/java/org/apache/accumulo/server/util/ListInstances.java @@ -33,8 +33,9 @@ import org.apache.accumulo.core.conf.SiteConfiguration; import org.apache.accumulo.core.data.InstanceId; import org.apache.accumulo.core.fate.zookeeper.ServiceLock; -import org.apache.accumulo.core.fate.zookeeper.ZooCache; import org.apache.accumulo.core.fate.zookeeper.ZooReader; +import org.apache.accumulo.core.fate.zookeeper.ZooSession; +import org.apache.zookeeper.ZooKeeper; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -84,7 +85,7 @@ static synchronized void listInstances(String keepers, boolean printAll, boolean System.out.println("INFO : Using ZooKeepers " + keepers); ZooReader rdr = new ZooReader(keepers, ZOOKEEPER_TIMER_MILLIS); - ZooCache cache = new ZooCache(rdr, null); + ZooKeeper zk = ZooSession.getAnonymousSession(keepers, ZOOKEEPER_TIMER_MILLIS); TreeMap instanceNames = getInstanceNames(rdr, printErrors); @@ -92,7 +93,7 @@ static synchronized void listInstances(String keepers, boolean printAll, boolean printHeader(); for (Entry entry : instanceNames.entrySet()) { - printInstanceInfo(cache, entry.getKey(), entry.getValue(), printErrors); + printInstanceInfo(zk, entry.getKey(), entry.getValue(), printErrors); } TreeSet instancedIds = getInstanceIDs(rdr, printErrors); @@ -100,7 +101,7 @@ static synchronized void listInstances(String keepers, boolean printAll, boolean if (printAll) { for (InstanceId uuid : instancedIds) { - printInstanceInfo(cache, null, uuid, printErrors); + printInstanceInfo(zk, null, uuid, printErrors); } } else if (!instancedIds.isEmpty()) { System.out.println(); @@ -140,9 +141,9 @@ private static void printHeader() { } - private static void printInstanceInfo(ZooCache cache, String instanceName, InstanceId iid, + private static void printInstanceInfo(ZooKeeper zk, String instanceName, InstanceId iid, boolean printErrors) { - String manager = getManager(cache, iid, printErrors); + String manager = getManager(zk, iid, printErrors); if (instanceName == null) { instanceName = ""; } @@ -155,7 +156,7 @@ private static void printInstanceInfo(ZooCache cache, String instanceName, Insta "\"" + instanceName + "\"", iid, manager); } - private static String getManager(ZooCache cache, InstanceId iid, boolean printErrors) { + private static String getManager(ZooKeeper zk, InstanceId iid, boolean printErrors) { if (iid == null) { return null; @@ -164,7 +165,7 @@ private static String getManager(ZooCache cache, InstanceId iid, boolean printEr try { var zLockManagerPath = ServiceLock.path(Constants.ZROOT + "/" + iid + Constants.ZMANAGER_LOCK); - byte[] manager = ServiceLock.getLockData(cache, zLockManagerPath, null); + byte[] manager = ServiceLock.getLockData(zk, zLockManagerPath); if (manager == null) { return null; }