Skip to content

Commit

Permalink
HBASE-14423 TestStochasticBalancerJmxMetrics.testJmxMetrics_PerTableM…
Browse files Browse the repository at this point in the history
…ode:183 NullPointer
  • Loading branch information
saintstack committed Sep 13, 2015
1 parent a915737 commit 439ca07
Showing 1 changed file with 36 additions and 8 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,10 @@

import static org.junit.Assert.assertTrue;

import java.io.IOException;
import java.util.HashSet;
import java.util.Hashtable;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Random;
Expand All @@ -30,6 +32,7 @@
import javax.management.MBeanAttributeInfo;
import javax.management.MBeanInfo;
import javax.management.MBeanServerConnection;
import javax.management.ObjectInstance;
import javax.management.ObjectName;
import javax.management.remote.JMXConnector;
import javax.management.remote.JMXConnectorFactory;
Expand All @@ -42,6 +45,7 @@
import org.apache.hadoop.hbase.master.balancer.StochasticLoadBalancer;
import org.apache.hadoop.hbase.testclassification.MediumTests;
import org.apache.hadoop.hbase.testclassification.MiscTests;
import org.apache.hadoop.hbase.util.Threads;
import org.apache.hadoop.net.DNSToSwitchMapping;
import org.junit.AfterClass;
import org.junit.BeforeClass;
Expand Down Expand Up @@ -114,7 +118,7 @@ public static void tearDownAfterClass() throws Exception {
/**
* In Ensemble mode, there should be only one ensemble table
*/
@Test
@Test (timeout=60000)
public void testJmxMetrics_EnsembleMode() throws Exception {
loadBalancer = new StochasticLoadBalancer();

Expand All @@ -127,7 +131,7 @@ public void testJmxMetrics_EnsembleMode() throws Exception {

String[] tableNames = new String[] { tableName.getNameAsString() };
String[] functionNames = loadBalancer.getCostFunctionNames();
Set<String> jmxMetrics = readJmxMetrics();
Set<String> jmxMetrics = readJmxMetricsWithRetry();
Set<String> expectedMetrics = getExpectedJmxMetrics(tableNames, functionNames);

// printMetrics(jmxMetrics, "existing metrics in ensemble mode");
Expand All @@ -143,7 +147,7 @@ public void testJmxMetrics_EnsembleMode() throws Exception {
/**
* In per-table mode, each table has a set of metrics
*/
@Test
@Test (timeout=60000)
public void testJmxMetrics_PerTableMode() throws Exception {
loadBalancer = new StochasticLoadBalancer();

Expand Down Expand Up @@ -172,7 +176,7 @@ public void testJmxMetrics_PerTableMode() throws Exception {
loadBalancer.balanceCluster(tableName, clusterState);

String[] tableNames = new String[] { TABLE_NAME_1, TABLE_NAME_2, TABLE_NAME_NAMESPACE };
Set<String> jmxMetrics = readJmxMetrics();
Set<String> jmxMetrics = readJmxMetricsWithRetry();
Set<String> expectedMetrics = getExpectedJmxMetrics(tableNames, functionNames);

// printMetrics(jmxMetrics, "existing metrics in per-table mode");
Expand All @@ -185,21 +189,35 @@ public void testJmxMetrics_PerTableMode() throws Exception {
}
}

private Set<String> readJmxMetricsWithRetry() throws IOException {
final int count = 0;
for (int i = 0; i < 10; i++) {
Set<String> metrics = readJmxMetrics();
if (metrics != null) return metrics;
LOG.warn("Failed to get jmxmetrics... sleeping, retrying; " + i + " of " + count + " times");
Threads.sleep(1000);
}
return null;
}

/**
* Read the attributes from Hadoop->HBase->Master->Balancer in JMX
* @throws IOException
*/
private Set<String> readJmxMetrics() {
private Set<String> readJmxMetrics() throws IOException {
JMXConnector connector = null;
ObjectName target = null;
MBeanServerConnection mb = null;
try {
connector =
JMXConnectorFactory.connect(JMXListener.buildJMXServiceURL(connectorPort, connectorPort));
MBeanServerConnection mb = connector.getMBeanServerConnection();
mb = connector.getMBeanServerConnection();

Hashtable<String, String> pairs = new Hashtable<>();
pairs.put("service", "HBase");
pairs.put("name", "Master");
pairs.put("sub", "Balancer");
ObjectName target = new ObjectName("Hadoop", pairs);
target = new ObjectName("Hadoop", pairs);
MBeanInfo beanInfo = mb.getMBeanInfo(target);

Set<String> existingAttrs = new HashSet<String>();
Expand All @@ -208,7 +226,17 @@ private Set<String> readJmxMetrics() {
}
return existingAttrs;
} catch (Exception e) {
e.printStackTrace();
LOG.warn("Failed to get bean!!! " + target, e);
if (mb != null) {
Set<ObjectInstance> instances = mb.queryMBeans(null, null);
Iterator<ObjectInstance> iterator = instances.iterator();
System.out.println("MBean Found:");
while (iterator.hasNext()) {
ObjectInstance instance = iterator.next();
System.out.println("Class Name: " + instance.getClassName());
System.out.println("Object Name: " + instance.getObjectName());
}
}
} finally {
if (connector != null) {
try {
Expand Down

0 comments on commit 439ca07

Please sign in to comment.