From 56ebf9387084b75a030f1f42030ff4d45e9de951 Mon Sep 17 00:00:00 2001 From: liuzhongjun Date: Wed, 11 Jan 2023 18:03:20 +0800 Subject: [PATCH] HBASE-27560 fix consistencyCheck did not report the hole on last region (#4950) Signed-off-by: Duo Zhang (cherry picked from commit c1b9d8ba068ab909174b5a21d3b2fa7f69578bef) --- .../master/janitor/ReportMakingVisitor.java | 6 ++--- .../janitor/TestCatalogJanitorCluster.java | 24 ++++++++++++++++--- 2 files changed, 24 insertions(+), 6 deletions(-) diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/master/janitor/ReportMakingVisitor.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/master/janitor/ReportMakingVisitor.java index 20b24ada2a5f..b604216751cd 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/master/janitor/ReportMakingVisitor.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/master/janitor/ReportMakingVisitor.java @@ -180,10 +180,10 @@ private RegionInfo metaTableConsistencyCheck(Result metaTableRow) { addOverlap(this.highestEndKeyRegionInfo, ri); } } + this.previous = ri; + this.highestEndKeyRegionInfo = + MetaFixer.getRegionInfoWithLargestEndKey(this.highestEndKeyRegionInfo, ri); } - this.previous = ri; - this.highestEndKeyRegionInfo = - MetaFixer.getRegionInfoWithLargestEndKey(this.highestEndKeyRegionInfo, ri); return ri; } diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/master/janitor/TestCatalogJanitorCluster.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/master/janitor/TestCatalogJanitorCluster.java index a0af5cdaeb9b..85426a4ead42 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/master/janitor/TestCatalogJanitorCluster.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/master/janitor/TestCatalogJanitorCluster.java @@ -31,6 +31,7 @@ import org.apache.hadoop.hbase.HConstants; import org.apache.hadoop.hbase.MetaTableAccessor; import org.apache.hadoop.hbase.TableName; +import org.apache.hadoop.hbase.TableNotEnabledException; import org.apache.hadoop.hbase.client.Put; import org.apache.hadoop.hbase.client.RegionInfo; import org.apache.hadoop.hbase.client.RegionInfoBuilder; @@ -66,6 +67,8 @@ public class TestCatalogJanitorCluster { private static final TableName T3 = TableName.valueOf("t3"); private static final TableName T4 = TableName.valueOf("t4"); private static final TableName T5 = TableName.valueOf("t5"); + private static final TableName T6 = TableName.valueOf("t6"); + private static final TableName T7 = TableName.valueOf("t7"); @Before public void before() throws Exception { @@ -82,6 +85,9 @@ public void before() throws Exception { final byte[][] keysForT5 = { Bytes.toBytes("bb"), Bytes.toBytes("cc"), Bytes.toBytes("dd") }; TEST_UTIL.createTable(T5, HConstants.CATALOG_FAMILY, keysForT5); + + TEST_UTIL.createMultiRegionTable(T6, new byte[][] { HConstants.CATALOG_FAMILY }); + TEST_UTIL.createMultiRegionTable(T7, new byte[][] { HConstants.CATALOG_FAMILY }); } @After @@ -227,7 +233,7 @@ private static byte[] incrementRow(byte[] row) { } @Test - public void testHoles() throws IOException { + public void testHoles() throws IOException, InterruptedException { CatalogJanitor janitor = TEST_UTIL.getHBaseCluster().getMaster().getCatalogJanitor(); CatalogJanitorReport report = janitor.getLastReport(); @@ -237,6 +243,9 @@ public void testHoles() throws IOException { verifyCornerHoles(janitor, T1); // Verify start and end region holes verifyCornerHoles(janitor, T2); + // Verify start and end region holes when next table is disable see: HBASE-27560 + disableTable(T7); + verifyCornerHoles(janitor, T6); verifyMiddleHole(janitor); // Verify that MetaFixer is able to fix these holes fixHoles(janitor); @@ -246,8 +255,8 @@ private void fixHoles(CatalogJanitor janitor) throws IOException { MetaFixer metaFixer = new MetaFixer(TEST_UTIL.getHBaseCluster().getMaster()); janitor.scan(); CatalogJanitorReport report = janitor.getLastReport(); - // Verify total number of holes, 2 in t1 and t2 each and one in t3 - assertEquals("Number of holes are not matching", 5, report.getHoles().size()); + // Verify total number of holes, 2 in t1, t2, t6 each and one in t3 + assertEquals("Number of holes are not matching", 7, report.getHoles().size()); metaFixer.fix(); janitor.scan(); report = janitor.getLastReport(); @@ -320,4 +329,13 @@ private RegionInfo getRegionInfo(TableName tableName, byte[] row) throws IOExcep assertNotNull(regionInfo); return regionInfo; } + + private void disableTable(TableName tableName) throws IOException, InterruptedException { + try { + TEST_UTIL.getAdmin().disableTable(tableName); + TEST_UTIL.waitTableDisabled(tableName, 30000); + } catch (TableNotEnabledException e) { + LOG.debug("Table: " + tableName + " already disabled, ignore."); + } + } }