HBASE-13923 Loaded region coprocessors are not reported in shell status command (Ashish Singhi)

This commit is contained in:
tedyu 2015-06-23 21:25:50 -07:00
parent 645d7ece12
commit b7f241d73b
2 changed files with 36 additions and 17 deletions

View File

@ -115,6 +115,7 @@ import org.apache.hadoop.hbase.protobuf.generated.ClusterStatusProtos;
import org.apache.hadoop.hbase.protobuf.generated.ClusterStatusProtos.RegionLoad; import org.apache.hadoop.hbase.protobuf.generated.ClusterStatusProtos.RegionLoad;
import org.apache.hadoop.hbase.protobuf.generated.ClusterStatusProtos.RegionStoreSequenceIds; import org.apache.hadoop.hbase.protobuf.generated.ClusterStatusProtos.RegionStoreSequenceIds;
import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.Coprocessor; import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.Coprocessor;
import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.Coprocessor.Builder;
import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.NameStringPair; import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.NameStringPair;
import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.RegionServerInfo; import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.RegionServerInfo;
import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.RegionSpecifier; import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.RegionSpecifier;
@ -1174,17 +1175,22 @@ public class HRegionServer extends HasThread implements
serverLoad.setUsedHeapMB((int)(memory.getUsed() / 1024 / 1024)); serverLoad.setUsedHeapMB((int)(memory.getUsed() / 1024 / 1024));
serverLoad.setMaxHeapMB((int) (memory.getMax() / 1024 / 1024)); serverLoad.setMaxHeapMB((int) (memory.getMax() / 1024 / 1024));
Set<String> coprocessors = getWAL(null).getCoprocessorHost().getCoprocessors(); Set<String> coprocessors = getWAL(null).getCoprocessorHost().getCoprocessors();
Builder coprocessorBuilder = Coprocessor.newBuilder();
for (String coprocessor : coprocessors) { for (String coprocessor : coprocessors) {
serverLoad.addCoprocessors( serverLoad.addCoprocessors(coprocessorBuilder.setName(coprocessor).build());
Coprocessor.newBuilder().setName(coprocessor).build());
} }
RegionLoad.Builder regionLoadBldr = RegionLoad.newBuilder(); RegionLoad.Builder regionLoadBldr = RegionLoad.newBuilder();
RegionSpecifier.Builder regionSpecifier = RegionSpecifier.newBuilder(); RegionSpecifier.Builder regionSpecifier = RegionSpecifier.newBuilder();
for (Region region : regions) { for (Region region : regions) {
Set<String> regionCoprocessors = region.getCoprocessorHost().getCoprocessors();
Iterator<String> iterator = regionCoprocessors.iterator();
while (iterator.hasNext()) {
serverLoad.addCoprocessors(coprocessorBuilder.setName(iterator.next()).build());
}
serverLoad.addRegionLoads(createRegionLoad(region, regionLoadBldr, regionSpecifier)); serverLoad.addRegionLoads(createRegionLoad(region, regionLoadBldr, regionSpecifier));
for (String coprocessor : for (String coprocessor : getWAL(region.getRegionInfo()).getCoprocessorHost()
getWAL(region.getRegionInfo()).getCoprocessorHost().getCoprocessors()) { .getCoprocessors()) {
serverLoad.addCoprocessors(Coprocessor.newBuilder().setName(coprocessor).build()); serverLoad.addCoprocessors(coprocessorBuilder.setName(coprocessor).build());
} }
} }
serverLoad.setReportStartTime(reportStartTime); serverLoad.setReportStartTime(reportStartTime);

View File

@ -75,6 +75,10 @@ public class TestClassLoading {
regionServerCoprocessor.getSimpleName() regionServerCoprocessor.getSimpleName()
}; };
private static final String[] masterRegionServerSystemCoprocessors = new String[] {
regionCoprocessor1.getSimpleName(), MultiRowMutationEndpoint.class.getSimpleName(),
regionServerCoprocessor.getSimpleName() };
@BeforeClass @BeforeClass
public static void setUpBeforeClass() throws Exception { public static void setUpBeforeClass() throws Exception {
Configuration conf = TEST_UTIL.getConfiguration(); Configuration conf = TEST_UTIL.getConfiguration();
@ -447,7 +451,7 @@ public class TestClassLoading {
// This was a test for HBASE-4070. // This was a test for HBASE-4070.
// We are removing coprocessors from region load in HBASE-5258. // We are removing coprocessors from region load in HBASE-5258.
// Therefore, this test now only checks system coprocessors. // Therefore, this test now only checks system coprocessors.
assertAllRegionServers(regionServerSystemCoprocessors,null); assertAllRegionServers(null);
} }
/** /**
@ -478,20 +482,18 @@ public class TestClassLoading {
return serverLoadHashMap; return serverLoadHashMap;
} }
void assertAllRegionServers(String[] expectedCoprocessors, String tableName) void assertAllRegionServers(String tableName) throws InterruptedException {
throws InterruptedException {
Map<ServerName, ServerLoad> servers; Map<ServerName, ServerLoad> servers;
String[] actualCoprocessors = null; String[] actualCoprocessors = null;
boolean success = false; boolean success = false;
for(int i = 0; i < 5; i++) { String[] expectedCoprocessors = regionServerSystemCoprocessors;
if (tableName == null) { if (tableName == null) {
// if no tableName specified, use all servers. // if no tableName specified, use all servers.
servers = servers = TEST_UTIL.getMiniHBaseCluster().getMaster().getServerManager().getOnlineServers();
TEST_UTIL.getMiniHBaseCluster().getMaster().getServerManager().
getOnlineServers();
} else { } else {
servers = serversForTable(tableName); servers = serversForTable(tableName);
} }
for (int i = 0; i < 5; i++) {
boolean any_failed = false; boolean any_failed = false;
for(Map.Entry<ServerName,ServerLoad> server: servers.entrySet()) { for(Map.Entry<ServerName,ServerLoad> server: servers.entrySet()) {
actualCoprocessors = server.getValue().getRsCoprocessors(); actualCoprocessors = server.getValue().getRsCoprocessors();
@ -500,8 +502,10 @@ public class TestClassLoading {
Arrays.toString(actualCoprocessors) + Arrays.toString(actualCoprocessors) +
" ; expected: " + Arrays.toString(expectedCoprocessors)); " ; expected: " + Arrays.toString(expectedCoprocessors));
any_failed = true; any_failed = true;
expectedCoprocessors = switchExpectedCoprocessors(expectedCoprocessors);
break; break;
} }
expectedCoprocessors = switchExpectedCoprocessors(expectedCoprocessors);
} }
if (any_failed == false) { if (any_failed == false) {
success = true; success = true;
@ -513,6 +517,15 @@ public class TestClassLoading {
assertTrue(success); assertTrue(success);
} }
private String[] switchExpectedCoprocessors(String[] expectedCoprocessors) {
if (Arrays.equals(regionServerSystemCoprocessors, expectedCoprocessors)) {
expectedCoprocessors = masterRegionServerSystemCoprocessors;
} else {
expectedCoprocessors = regionServerSystemCoprocessors;
}
return expectedCoprocessors;
}
@Test @Test
public void testMasterCoprocessorsReported() { public void testMasterCoprocessorsReported() {
// HBASE 4070: Improve region server metrics to report loaded coprocessors // HBASE 4070: Improve region server metrics to report loaded coprocessors