From b96f560255c8589380fb01a02ccfa21e15b1a63b Mon Sep 17 00:00:00 2001 From: Himanshu Gupta Date: Mon, 21 Dec 2015 23:23:20 -0600 Subject: [PATCH] emit query/node/bytes metric --- docs/content/operations/metrics.md | 1 + server/src/main/java/io/druid/client/DirectDruidClient.java | 1 + 2 files changed, 2 insertions(+) diff --git a/docs/content/operations/metrics.md b/docs/content/operations/metrics.md index 24afd51bced2..a3964d4a1021 100644 --- a/docs/content/operations/metrics.md +++ b/docs/content/operations/metrics.md @@ -30,6 +30,7 @@ Available Metrics |------|-----------|----------|------------| |`query/time`|Milliseconds taken to complete a query.|Common: dataSource, type, interval, hasFilters, duration, context, remoteAddress, id. Aggregation Queries: numMetrics, numComplexMetrics. GroupBy: numDimensions. TopN: threshold, dimension.|< 1s| |`query/node/time`|Milliseconds taken to query individual historical/realtime nodes.|id, status, server.|< 1s| +|`query/node/bytes`|bytes returned from querying individual historical/realtime nodes.|id, status, server.| | |`query/node/ttfb`|Time to first byte. Milliseconds elapsed until broker starts receiving the response from individual historical/realtime nodes.|id, status, server.|< 1s| |`query/intervalChunk/time`|Only emitted if interval chunking is enabled. Milliseconds required to query an interval chunk.|id, status, chunkInterval (if interval chunking is enabled).|< 1s| diff --git a/server/src/main/java/io/druid/client/DirectDruidClient.java b/server/src/main/java/io/druid/client/DirectDruidClient.java index d24176235480..92cbefc5487b 100644 --- a/server/src/main/java/io/druid/client/DirectDruidClient.java +++ b/server/src/main/java/io/druid/client/DirectDruidClient.java @@ -278,6 +278,7 @@ public ClientResponse done(ClientResponse clientRespon byteCount.get() / (0.0001 * (stopTime - responseStartTime)) ); emitter.emit(builder.build("query/node/time", stopTime - requestStartTime)); + emitter.emit(builder.build("query/node/bytes", byteCount.get())); synchronized (done) { try { // An empty byte array is put at the end to give the SequenceInputStream.close() as something to close out