HBASE-22874 Define a public API for Canary checking and a non-public tool implementation
Closes #580 * Canary is now an IA.Public interface * CanaryTool is now the implementation Signed-off-by: Sean Busbey <busbey@apache.org>
This commit is contained in:
parent
7ee6d59ef8
commit
5aa8d3a20b
|
@ -643,7 +643,7 @@ elif [ "$COMMAND" = "ltt" ] ; then
|
|||
CLASS='org.apache.hadoop.hbase.util.LoadTestTool'
|
||||
HBASE_OPTS="$HBASE_OPTS $HBASE_LTT_OPTS"
|
||||
elif [ "$COMMAND" = "canary" ] ; then
|
||||
CLASS='org.apache.hadoop.hbase.tool.Canary'
|
||||
CLASS='org.apache.hadoop.hbase.tool.CanaryTool'
|
||||
HBASE_OPTS="$HBASE_OPTS $HBASE_CANARY_OPTS"
|
||||
elif [ "$COMMAND" = "version" ] ; then
|
||||
CLASS='org.apache.hadoop.hbase.util.VersionInfo'
|
||||
|
|
|
@ -55,7 +55,7 @@ org.apache.hadoop.hbase.quotas.QuotaUtil;
|
|||
org.apache.hadoop.hbase.security.access.PermissionStorage;
|
||||
org.apache.hadoop.hbase.security.visibility.VisibilityConstants;
|
||||
org.apache.hadoop.hbase.shaded.protobuf.generated.SnapshotProtos.SnapshotDescription;
|
||||
org.apache.hadoop.hbase.tool.Canary;
|
||||
org.apache.hadoop.hbase.tool.CanaryTool;
|
||||
org.apache.hadoop.hbase.util.Bytes;
|
||||
org.apache.hadoop.hbase.util.FSUtils;
|
||||
org.apache.hadoop.hbase.util.JvmVersion;
|
||||
|
@ -513,7 +513,7 @@ AssignmentManager assignmentManager = master.getAssignmentManager();
|
|||
<%java>String description = null;
|
||||
if (tableName.equals(TableName.META_TABLE_NAME)){
|
||||
description = "The hbase:meta table holds references to all User Table regions.";
|
||||
} else if (tableName.equals(Canary.DEFAULT_WRITE_TABLE_NAME)){
|
||||
} else if (tableName.equals(CanaryTool.DEFAULT_WRITE_TABLE_NAME)){
|
||||
description = "The hbase:canary table is used to sniff the write availbility of"
|
||||
+ " each regionserver.";
|
||||
} else if (tableName.equals(PermissionStorage.ACL_TABLE_NAME)){
|
||||
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
|
@ -53,7 +53,6 @@ import org.apache.log4j.spi.LoggingEvent;
|
|||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
import org.junit.ClassRule;
|
||||
import org.junit.Ignore;
|
||||
import org.junit.Rule;
|
||||
import org.junit.Test;
|
||||
import org.junit.experimental.categories.Category;
|
||||
|
@ -120,8 +119,8 @@ public class TestCanaryTool {
|
|||
table.put(p);
|
||||
}
|
||||
ExecutorService executor = new ScheduledThreadPoolExecutor(1);
|
||||
Canary.RegionStdOutSink sink = spy(new Canary.RegionStdOutSink());
|
||||
Canary canary = new Canary(executor, sink);
|
||||
CanaryTool.RegionStdOutSink sink = spy(new CanaryTool.RegionStdOutSink());
|
||||
CanaryTool canary = new CanaryTool(executor, sink);
|
||||
String[] args = { "-writeSniffing", "-t", "10000", tableName.getNameAsString() };
|
||||
assertEquals(0, ToolRunner.run(testingUtility.getConfiguration(), canary, args));
|
||||
assertEquals("verify no read error count", 0, canary.getReadFailures().size());
|
||||
|
@ -142,8 +141,8 @@ public class TestCanaryTool {
|
|||
table.put(p);
|
||||
}
|
||||
ExecutorService executor = new ScheduledThreadPoolExecutor(1);
|
||||
Canary.RegionStdOutSink sink = spy(new Canary.RegionStdOutSink());
|
||||
Canary canary = new Canary(executor, sink);
|
||||
CanaryTool.RegionStdOutSink sink = spy(new CanaryTool.RegionStdOutSink());
|
||||
CanaryTool canary = new CanaryTool(executor, sink);
|
||||
String[] args = { "-writeSniffing", "-t", "10000", "testCanaryRegionTaskResult" };
|
||||
assertEquals(0, ToolRunner.run(testingUtility.getConfiguration(), canary, args));
|
||||
|
||||
|
@ -156,11 +155,11 @@ public class TestCanaryTool {
|
|||
|
||||
assertTrue("canary should expect to scan at least 1 region",
|
||||
sink.getTotalExpectedRegions() > 0);
|
||||
Map<String, Canary.RegionTaskResult> regionMap = sink.getRegionMap();
|
||||
Map<String, CanaryTool.RegionTaskResult> regionMap = sink.getRegionMap();
|
||||
assertFalse("verify region map has size > 0", regionMap.isEmpty());
|
||||
|
||||
for (String regionName : regionMap.keySet()) {
|
||||
Canary.RegionTaskResult res = regionMap.get(regionName);
|
||||
CanaryTool.RegionTaskResult res = regionMap.get(regionName);
|
||||
assertNotNull("verify each expected region has a RegionTaskResult object in the map", res);
|
||||
assertNotNull("verify getRegionNameAsString()", regionName);
|
||||
assertNotNull("verify getRegionInfo()", res.getRegionInfo());
|
||||
|
@ -169,7 +168,7 @@ public class TestCanaryTool {
|
|||
assertNotNull("verify getServerName()", res.getServerName());
|
||||
assertNotNull("verify getServerNameAsString()", res.getServerNameAsString());
|
||||
|
||||
if (regionName.contains(Canary.DEFAULT_WRITE_TABLE_NAME.getNameAsString())) {
|
||||
if (regionName.contains(CanaryTool.DEFAULT_WRITE_TABLE_NAME.getNameAsString())) {
|
||||
assertTrue("write to region " + regionName + " succeeded", res.isWriteSuccess());
|
||||
assertTrue("write took some time", res.getWriteLatency() > -1);
|
||||
} else {
|
||||
|
@ -180,7 +179,6 @@ public class TestCanaryTool {
|
|||
}
|
||||
|
||||
@Test
|
||||
@Ignore("Intermittent argument matching failures, see HBASE-18813")
|
||||
public void testReadTableTimeouts() throws Exception {
|
||||
final TableName [] tableNames = new TableName[2];
|
||||
tableNames[0] = TableName.valueOf(name.getMethodName() + "1");
|
||||
|
@ -197,8 +195,8 @@ public class TestCanaryTool {
|
|||
}
|
||||
}
|
||||
ExecutorService executor = new ScheduledThreadPoolExecutor(1);
|
||||
Canary.RegionStdOutSink sink = spy(new Canary.RegionStdOutSink());
|
||||
Canary canary = new Canary(executor, sink);
|
||||
CanaryTool.RegionStdOutSink sink = spy(new CanaryTool.RegionStdOutSink());
|
||||
CanaryTool canary = new CanaryTool(executor, sink);
|
||||
String configuredTimeoutStr = tableNames[0].getNameAsString() + "=" + Long.MAX_VALUE + "," +
|
||||
tableNames[1].getNameAsString() + "=0";
|
||||
String[] args = {"-readTableTimeouts", configuredTimeoutStr, name.getMethodName() + "1",
|
||||
|
@ -219,17 +217,16 @@ public class TestCanaryTool {
|
|||
verify(mockAppender, times(2)).doAppend(argThat(new ArgumentMatcher<LoggingEvent>() {
|
||||
@Override
|
||||
public boolean matches(LoggingEvent argument) {
|
||||
return argument.getRenderedMessage().contains("The configured read timeout was");
|
||||
return argument.getRenderedMessage().contains("Configured read timeout");
|
||||
}
|
||||
}));
|
||||
}
|
||||
|
||||
@Test
|
||||
@Ignore("Intermittent argument matching failures, see HBASE-18813")
|
||||
public void testWriteTableTimeout() throws Exception {
|
||||
ExecutorService executor = new ScheduledThreadPoolExecutor(1);
|
||||
Canary.RegionStdOutSink sink = spy(new Canary.RegionStdOutSink());
|
||||
Canary canary = new Canary(executor, sink);
|
||||
CanaryTool.RegionStdOutSink sink = spy(new CanaryTool.RegionStdOutSink());
|
||||
CanaryTool canary = new CanaryTool(executor, sink);
|
||||
String[] args = { "-writeSniffing", "-writeTableTimeout", String.valueOf(Long.MAX_VALUE)};
|
||||
assertEquals(0, ToolRunner.run(testingUtility.getConfiguration(), canary, args));
|
||||
assertNotEquals("verify non-null write latency", null, sink.getWriteLatency());
|
||||
|
@ -238,7 +235,7 @@ public class TestCanaryTool {
|
|||
new ArgumentMatcher<LoggingEvent>() {
|
||||
@Override
|
||||
public boolean matches(LoggingEvent argument) {
|
||||
return argument.getRenderedMessage().contains("The configured write timeout was");
|
||||
return argument.getRenderedMessage().contains("Configured write timeout");
|
||||
}
|
||||
}));
|
||||
}
|
||||
|
@ -281,8 +278,8 @@ public class TestCanaryTool {
|
|||
table.put(p);
|
||||
}
|
||||
ExecutorService executor = new ScheduledThreadPoolExecutor(1);
|
||||
Canary.RegionStdOutSink sink = spy(new Canary.RegionStdOutSink());
|
||||
Canary canary = new Canary(executor, sink);
|
||||
CanaryTool.RegionStdOutSink sink = spy(new CanaryTool.RegionStdOutSink());
|
||||
CanaryTool canary = new CanaryTool(executor, sink);
|
||||
String[] args = { "-t", "10000", name.getMethodName() };
|
||||
org.apache.hadoop.conf.Configuration conf =
|
||||
new org.apache.hadoop.conf.Configuration(testingUtility.getConfiguration());
|
||||
|
@ -296,7 +293,7 @@ public class TestCanaryTool {
|
|||
|
||||
private void runRegionserverCanary() throws Exception {
|
||||
ExecutorService executor = new ScheduledThreadPoolExecutor(1);
|
||||
Canary canary = new Canary(executor, new Canary.RegionServerStdOutSink());
|
||||
CanaryTool canary = new CanaryTool(executor, new CanaryTool.RegionServerStdOutSink());
|
||||
String[] args = { "-t", "10000", "-regionserver"};
|
||||
assertEquals(0, ToolRunner.run(testingUtility.getConfiguration(), canary, args));
|
||||
assertEquals("verify no read error count", 0, canary.getReadFailures().size());
|
||||
|
@ -307,8 +304,8 @@ public class TestCanaryTool {
|
|||
Iterables.getOnlyElement(testingUtility.getZkCluster().getClientPortList(), null);
|
||||
testingUtility.getConfiguration().set(HConstants.ZOOKEEPER_QUORUM, "localhost:" + port);
|
||||
ExecutorService executor = new ScheduledThreadPoolExecutor(2);
|
||||
Canary.ZookeeperStdOutSink sink = spy(new Canary.ZookeeperStdOutSink());
|
||||
Canary canary = new Canary(executor, sink);
|
||||
CanaryTool.ZookeeperStdOutSink sink = spy(new CanaryTool.ZookeeperStdOutSink());
|
||||
CanaryTool canary = new CanaryTool(executor, sink);
|
||||
assertEquals(0, ToolRunner.run(testingUtility.getConfiguration(), canary, args));
|
||||
|
||||
String baseZnode = testingUtility.getConfiguration()
|
||||
|
|
Loading…
Reference in New Issue