HBASE-27845 Distinguish the mutate types of rpc error in MetricsConnection.
This commit is contained in:
parent
ef0ce71c7e
commit
b04e455bdc
|
@ -652,25 +652,26 @@ public final class MetricsConnection implements StatisticTrackable {
|
||||||
concurrentCallsPerServerHist.update(callsPerServer);
|
concurrentCallsPerServerHist.update(callsPerServer);
|
||||||
}
|
}
|
||||||
// Update the counter that tracks RPCs by type.
|
// Update the counter that tracks RPCs by type.
|
||||||
String methodName = method.getService().getName() + "_" + method.getName();
|
StringBuilder methodName = new StringBuilder();
|
||||||
|
methodName.append(method.getService().getName()).append("_").append(method.getName());
|
||||||
// Distinguish mutate types.
|
// Distinguish mutate types.
|
||||||
if ("Mutate".equals(method.getName())) {
|
if ("Mutate".equals(method.getName())) {
|
||||||
final MutationType type = ((MutateRequest) param).getMutation().getMutateType();
|
final MutationType type = ((MutateRequest) param).getMutation().getMutateType();
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case APPEND:
|
case APPEND:
|
||||||
methodName += "(Append)";
|
methodName.append("(Append)");
|
||||||
break;
|
break;
|
||||||
case DELETE:
|
case DELETE:
|
||||||
methodName += "(Delete)";
|
methodName.append("(Delete)");
|
||||||
break;
|
break;
|
||||||
case INCREMENT:
|
case INCREMENT:
|
||||||
methodName += "(Increment)";
|
methodName.append("(Increment)");
|
||||||
break;
|
break;
|
||||||
case PUT:
|
case PUT:
|
||||||
methodName += "(Put)";
|
methodName.append("(Put)");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw new RuntimeException("Unrecognized mutation type " + type);
|
methodName.append("(Unknown)");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
getMetric(CNT_BASE + methodName, rpcCounters, counterFactory).inc();
|
getMetric(CNT_BASE + methodName, rpcCounters, counterFactory).inc();
|
||||||
|
@ -749,7 +750,7 @@ public final class MetricsConnection implements StatisticTrackable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Fallback to dynamic registry lookup for DDL methods.
|
// Fallback to dynamic registry lookup for DDL methods.
|
||||||
updateRpcGeneric(methodName, stats);
|
updateRpcGeneric(methodName.toString(), stats);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void incrCacheDroppingExceptions(Object exception) {
|
public void incrCacheDroppingExceptions(Object exception) {
|
||||||
|
|
|
@ -99,7 +99,7 @@ public class TestMetricsConnection {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testMetricsWithMutiConnections() throws IOException {
|
public void testMetricsWithMultiConnections() throws IOException {
|
||||||
Configuration conf = new Configuration();
|
Configuration conf = new Configuration();
|
||||||
conf.setBoolean(MetricsConnection.CLIENT_SIDE_METRICS_ENABLED_KEY, true);
|
conf.setBoolean(MetricsConnection.CLIENT_SIDE_METRICS_ENABLED_KEY, true);
|
||||||
conf.set(MetricsConnection.METRICS_SCOPE_KEY, "unit-test");
|
conf.set(MetricsConnection.METRICS_SCOPE_KEY, "unit-test");
|
||||||
|
@ -192,17 +192,17 @@ public class TestMetricsConnection {
|
||||||
for (String method : new String[] { "Get", "Scan", "Multi" }) {
|
for (String method : new String[] { "Get", "Scan", "Multi" }) {
|
||||||
metricKey = rpcCountPrefix + method;
|
metricKey = rpcCountPrefix + method;
|
||||||
metricVal = METRICS.getRpcCounters().get(metricKey).getCount();
|
metricVal = METRICS.getRpcCounters().get(metricKey).getCount();
|
||||||
assertTrue("metric: " + metricKey + " val: " + metricVal, metricVal == loop);
|
assertEquals("metric: " + metricKey + " val: " + metricVal, metricVal, loop);
|
||||||
|
|
||||||
metricKey = rpcFailureCountPrefix + method;
|
metricKey = rpcFailureCountPrefix + method;
|
||||||
counter = METRICS.getRpcCounters().get(metricKey);
|
counter = METRICS.getRpcCounters().get(metricKey);
|
||||||
metricVal = (counter != null) ? counter.getCount() : 0;
|
metricVal = (counter != null) ? counter.getCount() : 0;
|
||||||
if (method.equals("Get")) {
|
if (method.equals("Get")) {
|
||||||
// no failure
|
// no failure
|
||||||
assertTrue("metric: " + metricKey + " val: " + metricVal, metricVal == 0);
|
assertEquals("metric: " + metricKey + " val: " + metricVal, 0, metricVal);
|
||||||
} else {
|
} else {
|
||||||
// has failure
|
// has failure
|
||||||
assertTrue("metric: " + metricKey + " val: " + metricVal, metricVal == loop);
|
assertEquals("metric: " + metricKey + " val: " + metricVal, metricVal, loop);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -210,17 +210,17 @@ public class TestMetricsConnection {
|
||||||
for (String mutationType : new String[] { "Append", "Delete", "Increment", "Put" }) {
|
for (String mutationType : new String[] { "Append", "Delete", "Increment", "Put" }) {
|
||||||
metricKey = rpcCountPrefix + method + "(" + mutationType + ")";
|
metricKey = rpcCountPrefix + method + "(" + mutationType + ")";
|
||||||
metricVal = METRICS.getRpcCounters().get(metricKey).getCount();
|
metricVal = METRICS.getRpcCounters().get(metricKey).getCount();
|
||||||
assertTrue("metric: " + metricKey + " val: " + metricVal, metricVal == loop);
|
assertEquals("metric: " + metricKey + " val: " + metricVal, metricVal, loop);
|
||||||
|
|
||||||
metricKey = rpcFailureCountPrefix + method + "(" + mutationType + ")";
|
metricKey = rpcFailureCountPrefix + method + "(" + mutationType + ")";
|
||||||
counter = METRICS.getRpcCounters().get(metricKey);
|
counter = METRICS.getRpcCounters().get(metricKey);
|
||||||
metricVal = (counter != null) ? counter.getCount() : 0;
|
metricVal = (counter != null) ? counter.getCount() : 0;
|
||||||
if (mutationType.equals("Put")) {
|
if (mutationType.equals("Put")) {
|
||||||
// no failure
|
|
||||||
assertTrue("metric: " + metricKey + " val: " + metricVal, metricVal == loop);
|
|
||||||
} else {
|
|
||||||
// has failure
|
// has failure
|
||||||
assertTrue("metric: " + metricKey + " val: " + metricVal, metricVal == 0);
|
assertEquals("metric: " + metricKey + " val: " + metricVal, metricVal, loop);
|
||||||
|
} else {
|
||||||
|
// no failure
|
||||||
|
assertEquals("metric: " + metricKey + " val: " + metricVal, 0, metricVal);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -228,19 +228,19 @@ public class TestMetricsConnection {
|
||||||
metricKey = "rpcRemoteExceptions_IOException";
|
metricKey = "rpcRemoteExceptions_IOException";
|
||||||
counter = METRICS.getRpcCounters().get(metricKey);
|
counter = METRICS.getRpcCounters().get(metricKey);
|
||||||
metricVal = (counter != null) ? counter.getCount() : 0;
|
metricVal = (counter != null) ? counter.getCount() : 0;
|
||||||
assertTrue("metric: " + metricKey + " val: " + metricVal, metricVal == loop);
|
assertEquals("metric: " + metricKey + " val: " + metricVal, metricVal, loop);
|
||||||
|
|
||||||
// local exception
|
// local exception
|
||||||
metricKey = "rpcLocalExceptions_CallTimeoutException";
|
metricKey = "rpcLocalExceptions_CallTimeoutException";
|
||||||
counter = METRICS.getRpcCounters().get(metricKey);
|
counter = METRICS.getRpcCounters().get(metricKey);
|
||||||
metricVal = (counter != null) ? counter.getCount() : 0;
|
metricVal = (counter != null) ? counter.getCount() : 0;
|
||||||
assertTrue("metric: " + metricKey + " val: " + metricVal, metricVal == loop * 2);
|
assertEquals("metric: " + metricKey + " val: " + metricVal, metricVal, loop * 2);
|
||||||
|
|
||||||
// total exception
|
// total exception
|
||||||
metricKey = "rpcTotalExceptions";
|
metricKey = "rpcTotalExceptions";
|
||||||
counter = METRICS.getRpcCounters().get(metricKey);
|
counter = METRICS.getRpcCounters().get(metricKey);
|
||||||
metricVal = (counter != null) ? counter.getCount() : 0;
|
metricVal = (counter != null) ? counter.getCount() : 0;
|
||||||
assertTrue("metric: " + metricKey + " val: " + metricVal, metricVal == loop * 3);
|
assertEquals("metric: " + metricKey + " val: " + metricVal, metricVal, loop * 3);
|
||||||
|
|
||||||
for (MetricsConnection.CallTracker t : new MetricsConnection.CallTracker[] {
|
for (MetricsConnection.CallTracker t : new MetricsConnection.CallTracker[] {
|
||||||
METRICS.getGetTracker(), METRICS.getScanTracker(), METRICS.getMultiTracker(),
|
METRICS.getGetTracker(), METRICS.getScanTracker(), METRICS.getMultiTracker(),
|
||||||
|
|
Loading…
Reference in New Issue