HADOOP-17081. MetricsSystem doesn't start the sink adapters on restart (#2089)
Contributed by Madhusoodan P
This commit is contained in:
parent
20df70a895
commit
0789ae5b78
@ -273,7 +273,11 @@ void registerSource(String name, String desc, MetricsSource source) {
|
|||||||
T register(final String name, final String description, final T sink) {
|
T register(final String name, final String description, final T sink) {
|
||||||
LOG.debug(name +", "+ description);
|
LOG.debug(name +", "+ description);
|
||||||
if (allSinks.containsKey(name)) {
|
if (allSinks.containsKey(name)) {
|
||||||
|
if(sinks.get(name) == null) {
|
||||||
|
registerSink(name, description, sink);
|
||||||
|
} else {
|
||||||
LOG.warn("Sink "+ name +" already exists!");
|
LOG.warn("Sink "+ name +" already exists!");
|
||||||
|
}
|
||||||
return sink;
|
return sink;
|
||||||
}
|
}
|
||||||
allSinks.put(name, sink);
|
allSinks.put(name, sink);
|
||||||
|
@ -639,4 +639,25 @@ private static class TestSource2 {
|
|||||||
private static String getPluginUrlsAsString() {
|
private static String getPluginUrlsAsString() {
|
||||||
return "file:metrics2-test-plugin.jar";
|
return "file:metrics2-test-plugin.jar";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testMetricSystemRestart() {
|
||||||
|
MetricsSystemImpl ms = new MetricsSystemImpl("msRestartTestSystem");
|
||||||
|
TestSink ts = new TestSink();
|
||||||
|
String sinkName = "restartTestSink";
|
||||||
|
|
||||||
|
try {
|
||||||
|
ms.start();
|
||||||
|
ms.register(sinkName, "", ts);
|
||||||
|
assertNotNull("no adapter exists for " + sinkName,
|
||||||
|
ms.getSinkAdapter(sinkName));
|
||||||
|
ms.stop();
|
||||||
|
|
||||||
|
ms.start();
|
||||||
|
assertNotNull("no adapter exists for " + sinkName,
|
||||||
|
ms.getSinkAdapter(sinkName));
|
||||||
|
} finally {
|
||||||
|
ms.stop();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user