HADOOP-11181. GraphiteSink emits wrong timestamps (Sascha Coenen via raviprak)
This commit is contained in:
parent
0af1a2b5bc
commit
466f08792f
@ -661,6 +661,8 @@ Release 2.6.0 - UNRELEASED
|
|||||||
|
|
||||||
BUG FIXES
|
BUG FIXES
|
||||||
|
|
||||||
|
HADOOP-11181. GraphiteSink emits wrong timestamps (Sascha Coenen via raviprak)
|
||||||
|
|
||||||
HADOOP-10781. Unportable getgrouplist() usage breaks FreeBSD (Dmitry
|
HADOOP-10781. Unportable getgrouplist() usage breaks FreeBSD (Dmitry
|
||||||
Sivachenko via Colin Patrick McCabe)
|
Sivachenko via Colin Patrick McCabe)
|
||||||
|
|
||||||
|
@ -89,8 +89,8 @@ public void putMetrics(MetricsRecord record) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Round the timestamp to second as Graphite accepts it in such format.
|
// The record timestamp is in milliseconds while Graphite expects an epoc time in seconds.
|
||||||
int timestamp = Math.round(record.timestamp() / 1000.0f);
|
long timestamp = record.timestamp() / 1000L;
|
||||||
|
|
||||||
// Collect datapoints.
|
// Collect datapoints.
|
||||||
for (AbstractMetric metric : record.metrics()) {
|
for (AbstractMetric metric : record.metrics()) {
|
||||||
|
@ -19,11 +19,16 @@
|
|||||||
package org.apache.hadoop.metrics2.impl;
|
package org.apache.hadoop.metrics2.impl;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.OutputStreamWriter;
|
import java.io.OutputStreamWriter;
|
||||||
import java.io.Writer;
|
import java.io.Writer;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
@ -34,8 +39,6 @@
|
|||||||
import org.apache.hadoop.metrics2.MetricsTag;
|
import org.apache.hadoop.metrics2.MetricsTag;
|
||||||
import org.apache.hadoop.metrics2.sink.GraphiteSink;
|
import org.apache.hadoop.metrics2.sink.GraphiteSink;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import static org.mockito.Mockito.*;
|
|
||||||
import org.mockito.ArgumentCaptor;
|
import org.mockito.ArgumentCaptor;
|
||||||
import org.mockito.internal.util.reflection.Whitebox;
|
import org.mockito.internal.util.reflection.Whitebox;
|
||||||
|
|
||||||
@ -108,6 +111,43 @@ public void testPutMetrics2() {
|
|||||||
result.equals("null.all.Context.Context=all.foo2 2 10\n" +
|
result.equals("null.all.Context.Context=all.foo2 2 10\n" +
|
||||||
"null.all.Context.Context=all.foo1 1 10\n"));
|
"null.all.Context.Context=all.foo1 1 10\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Assert that timestamps are converted correctly, ticket HADOOP-11182
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void testPutMetrics3() {
|
||||||
|
|
||||||
|
// setup GraphiteSink
|
||||||
|
GraphiteSink sink = new GraphiteSink();
|
||||||
|
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||||
|
Whitebox.setInternalState(sink, "writer", new OutputStreamWriter(out));
|
||||||
|
|
||||||
|
// given two metrics records with timestamps 1000 milliseconds apart.
|
||||||
|
List<MetricsTag> tags = Collections.emptyList();
|
||||||
|
Set<AbstractMetric> metrics = new HashSet<AbstractMetric>();
|
||||||
|
metrics.add(makeMetric("foo1", 1));
|
||||||
|
MetricsRecord record1 = new MetricsRecordImpl(MsInfo.Context, 1000000000000L, tags, metrics);
|
||||||
|
MetricsRecord record2 = new MetricsRecordImpl(MsInfo.Context, 1000000001000L, tags, metrics);
|
||||||
|
|
||||||
|
sink.putMetrics(record1);
|
||||||
|
sink.putMetrics(record2);
|
||||||
|
|
||||||
|
sink.flush();
|
||||||
|
try {
|
||||||
|
sink.close();
|
||||||
|
} catch(IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
// then the timestamps in the graphite stream should differ by one second.
|
||||||
|
String expectedOutput
|
||||||
|
= "null.default.Context.foo1 1 1000000000\n"
|
||||||
|
+ "null.default.Context.foo1 1 1000000001\n";
|
||||||
|
assertEquals(expectedOutput, out.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test(expected=MetricsException.class)
|
@Test(expected=MetricsException.class)
|
||||||
public void testCloseAndWrite() throws IOException {
|
public void testCloseAndWrite() throws IOException {
|
||||||
GraphiteSink sink = new GraphiteSink();
|
GraphiteSink sink = new GraphiteSink();
|
||||||
|
Loading…
Reference in New Issue
Block a user