From 32a20159342e23f662ec9bb6cb7b24d6192428ba Mon Sep 17 00:00:00 2001 From: linkaline Date: Fri, 16 Aug 2019 16:52:41 +0800 Subject: [PATCH] HBASE-22820 Do not need to persist default rs group now (#482) Signed-off-by: Duo Zhang --- .../hbase/rsgroup/RSGroupInfoManagerImpl.java | 40 +++++++++++-------- .../rsgroup/VerifyingRSGroupAdminClient.java | 25 ++++++++++++ 2 files changed, 49 insertions(+), 16 deletions(-) diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/rsgroup/RSGroupInfoManagerImpl.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/rsgroup/RSGroupInfoManagerImpl.java index 64f86f92ce05..a1c7749c3838 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/rsgroup/RSGroupInfoManagerImpl.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/rsgroup/RSGroupInfoManagerImpl.java @@ -403,11 +403,13 @@ private void flushConfigTable(Map groupMap) throws IOExcept } // populate puts - for (RSGroupInfo RSGroupInfo : groupMap.values()) { - RSGroupProtos.RSGroupInfo proto = ProtobufUtil.toProtoGroupInfo(RSGroupInfo); - Put p = new Put(Bytes.toBytes(RSGroupInfo.getName())); - p.addColumn(META_FAMILY_BYTES, META_QUALIFIER_BYTES, proto.toByteArray()); - mutations.add(p); + for (RSGroupInfo gi : groupMap.values()) { + if (!gi.getName().equals(RSGroupInfo.DEFAULT_GROUP)) { + RSGroupProtos.RSGroupInfo proto = ProtobufUtil.toProtoGroupInfo(gi); + Put p = new Put(Bytes.toBytes(gi.getName())); + p.addColumn(META_FAMILY_BYTES, META_QUALIFIER_BYTES, proto.toByteArray()); + mutations.add(p); + } } if (mutations.size() > 0) { @@ -456,7 +458,12 @@ private synchronized void flushConfig(Map newGroupMap) thro // Make changes visible after having been persisted to the source of truth resetRSGroupMap(newGroupMap); + saveRSGroupMapToZK(newGroupMap); + updateCacheOfRSGroups(newGroupMap.keySet()); + } + + private void saveRSGroupMapToZK(Map newGroupMap) throws IOException { try { String groupBasePath = ZNodePaths.joinZNode(watcher.getZNodePaths().baseZNode, RS_GROUP_ZNODE); @@ -470,14 +477,16 @@ private synchronized void flushConfig(Map newGroupMap) thro } } - for (RSGroupInfo RSGroupInfo : newGroupMap.values()) { - String znode = ZNodePaths.joinZNode(groupBasePath, RSGroupInfo.getName()); - RSGroupProtos.RSGroupInfo proto = ProtobufUtil.toProtoGroupInfo(RSGroupInfo); - LOG.debug("Updating znode: " + znode); - ZKUtil.createAndFailSilent(watcher, znode); - zkOps.add(ZKUtil.ZKUtilOp.deleteNodeFailSilent(znode)); - zkOps.add(ZKUtil.ZKUtilOp.createAndFailSilent(znode, - ProtobufUtil.prependPBMagic(proto.toByteArray()))); + for (RSGroupInfo gi : newGroupMap.values()) { + if (!gi.getName().equals(RSGroupInfo.DEFAULT_GROUP)) { + String znode = ZNodePaths.joinZNode(groupBasePath, gi.getName()); + RSGroupProtos.RSGroupInfo proto = ProtobufUtil.toProtoGroupInfo(gi); + LOG.debug("Updating znode: " + znode); + ZKUtil.createAndFailSilent(watcher, znode); + zkOps.add(ZKUtil.ZKUtilOp.deleteNodeFailSilent(znode)); + zkOps.add(ZKUtil.ZKUtilOp.createAndFailSilent(znode, + ProtobufUtil.prependPBMagic(proto.toByteArray()))); + } } LOG.debug("Writing ZK GroupInfo count: " + zkOps.size()); @@ -487,7 +496,6 @@ private synchronized void flushConfig(Map newGroupMap) thro masterServices.abort("Failed to write to rsGroupZNode", e); throw new IOException("Failed to write to rsGroupZNode", e); } - updateCacheOfRSGroups(newGroupMap.keySet()); } /** @@ -547,12 +555,12 @@ private SortedSet
getDefaultServers() throws IOException { // Called by ServerEventsListenerThread. Synchronize on this because redoing // the rsGroupMap then writing it out. - private synchronized void updateDefaultServers(SortedSet
servers) throws IOException { + private synchronized void updateDefaultServers(SortedSet
servers) { RSGroupInfo info = rsGroupMap.get(RSGroupInfo.DEFAULT_GROUP); RSGroupInfo newInfo = new RSGroupInfo(info.getName(), servers); HashMap newGroupMap = Maps.newHashMap(rsGroupMap); newGroupMap.put(newInfo.getName(), newInfo); - flushConfig(newGroupMap); + resetRSGroupMap(newGroupMap); } // Called by FailedOpenUpdaterThread diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/rsgroup/VerifyingRSGroupAdminClient.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/rsgroup/VerifyingRSGroupAdminClient.java index a8cd277e0552..28131a9fee82 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/rsgroup/VerifyingRSGroupAdminClient.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/rsgroup/VerifyingRSGroupAdminClient.java @@ -26,8 +26,11 @@ import java.util.List; import java.util.Map; import java.util.Set; +import java.util.SortedSet; +import java.util.regex.Pattern; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.hbase.NamespaceDescriptor; +import org.apache.hadoop.hbase.ServerName; import org.apache.hadoop.hbase.TableName; import org.apache.hadoop.hbase.client.Admin; import org.apache.hadoop.hbase.client.Connection; @@ -133,6 +136,13 @@ public void verify() throws IOException { tds.addAll(admin.listTableDescriptors()); tds.addAll(admin.listTableDescriptorsByNamespace(NamespaceDescriptor.SYSTEM_NAMESPACE_NAME)); } + SortedSet
lives = Sets.newTreeSet(); + for (ServerName sn : conn.getAdmin().getClusterMetrics().getLiveServerMetrics().keySet()) { + lives.add(sn.getAddress()); + } + for (ServerName sn : conn.getAdmin().listDecommissionedRegionServers()) { + lives.remove(sn.getAddress()); + } try (Table table = conn.getTable(RSGroupInfoManagerImpl.RSGROUP_TABLE_NAME); ResultScanner scanner = table.getScanner(new Scan())) { for (;;) { @@ -144,8 +154,22 @@ public void verify() throws IOException { RSGroupInfoManagerImpl.META_FAMILY_BYTES, RSGroupInfoManagerImpl.META_QUALIFIER_BYTES)); RSGroupInfo rsGroupInfo = ProtobufUtil.toGroupInfo(proto); groupMap.put(proto.getName(), RSGroupUtil.fillTables(rsGroupInfo, tds)); + for(Address address : rsGroupInfo.getServers()){ + lives.remove(address); + } } } + SortedSet tables = Sets.newTreeSet(); + for (TableDescriptor td : conn.getAdmin().listTableDescriptors(Pattern.compile(".*"), + true)){ + String groupName = td.getRegionServerGroup().orElse(RSGroupInfo.DEFAULT_GROUP); + if (groupName.equals(RSGroupInfo.DEFAULT_GROUP)) { + tables.add(td.getTableName()); + } + } + + groupMap.put(RSGroupInfo.DEFAULT_GROUP, + new RSGroupInfo(RSGroupInfo.DEFAULT_GROUP, lives, tables)); assertEquals(Sets.newHashSet(groupMap.values()), Sets.newHashSet(wrapped.listRSGroups())); try { String groupBasePath = ZNodePaths.joinZNode(zkw.getZNodePaths().baseZNode, "rsgroup"); @@ -160,6 +184,7 @@ public void verify() throws IOException { zList.add(RSGroupUtil.fillTables(rsGroupInfo, tds)); } } + groupMap.remove(RSGroupInfo.DEFAULT_GROUP); assertEquals(zList.size(), groupMap.size()); for (RSGroupInfo rsGroupInfo : zList) { assertTrue(groupMap.get(rsGroupInfo.getName()).equals(rsGroupInfo));