HADOOP-18875. ABFS: Add sendMs and recvMs information for each AbfsHttpOperation by default. (#6008)
Contributed By: Anmol Asrani
This commit is contained in:
parent
5edd21bc85
commit
ababe3d9b0
@ -79,8 +79,6 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
private int expectedBytesToBeSent;
|
||||
private long bytesReceived;
|
||||
|
||||
// optional trace enabled metrics
|
||||
private final boolean isTraceEnabled;
|
||||
private long connectionTimeMs;
|
||||
private long sendRequestTimeMs;
|
||||
private long recvResponseTimeMs;
|
||||
@ -104,7 +102,6 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
protected AbfsHttpOperation(final URL url,
|
||||
final String method,
|
||||
final int httpStatus) {
|
||||
this.isTraceEnabled = LOG.isTraceEnabled();
|
||||
this.url = url;
|
||||
this.method = method;
|
||||
this.statusCode = httpStatus;
|
||||
@ -188,14 +185,12 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
sb.append(getClientRequestId());
|
||||
sb.append(",rid=");
|
||||
sb.append(requestId);
|
||||
if (isTraceEnabled) {
|
||||
sb.append(",connMs=");
|
||||
sb.append(connectionTimeMs);
|
||||
sb.append(",sendMs=");
|
||||
sb.append(sendRequestTimeMs);
|
||||
sb.append(",recvMs=");
|
||||
sb.append(recvResponseTimeMs);
|
||||
}
|
||||
sb.append(",connMs=");
|
||||
sb.append(connectionTimeMs);
|
||||
sb.append(",sendMs=");
|
||||
sb.append(sendRequestTimeMs);
|
||||
sb.append(",recvMs=");
|
||||
sb.append(recvResponseTimeMs);
|
||||
sb.append(",sent=");
|
||||
sb.append(bytesSent);
|
||||
sb.append(",recv=");
|
||||
@ -218,18 +213,16 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
.append(" ci=")
|
||||
.append(getClientRequestId())
|
||||
.append(" ri=")
|
||||
.append(requestId);
|
||||
.append(requestId)
|
||||
|
||||
if (isTraceEnabled) {
|
||||
sb.append(" ct=")
|
||||
.append(connectionTimeMs)
|
||||
.append(" st=")
|
||||
.append(sendRequestTimeMs)
|
||||
.append(" rt=")
|
||||
.append(recvResponseTimeMs);
|
||||
}
|
||||
.append(" ct=")
|
||||
.append(connectionTimeMs)
|
||||
.append(" st=")
|
||||
.append(sendRequestTimeMs)
|
||||
.append(" rt=")
|
||||
.append(recvResponseTimeMs)
|
||||
|
||||
sb.append(" bs=")
|
||||
.append(" bs=")
|
||||
.append(bytesSent)
|
||||
.append(" br=")
|
||||
.append(bytesReceived)
|
||||
@ -271,7 +264,6 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
*/
|
||||
public AbfsHttpOperation(final URL url, final String method, final List<AbfsHttpHeader> requestHeaders)
|
||||
throws IOException {
|
||||
this.isTraceEnabled = LOG.isTraceEnabled();
|
||||
this.url = url;
|
||||
this.method = method;
|
||||
|
||||
@ -319,9 +311,7 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
// send the request body
|
||||
|
||||
long startTime = 0;
|
||||
if (this.isTraceEnabled) {
|
||||
startTime = System.nanoTime();
|
||||
}
|
||||
startTime = System.nanoTime();
|
||||
OutputStream outputStream = null;
|
||||
// Updates the expected bytes to be sent based on length.
|
||||
this.expectedBytesToBeSent = length;
|
||||
@ -360,9 +350,7 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
if (outputStream != null) {
|
||||
outputStream.close();
|
||||
}
|
||||
if (this.isTraceEnabled) {
|
||||
this.sendRequestTimeMs = elapsedTimeMs(startTime);
|
||||
}
|
||||
this.sendRequestTimeMs = elapsedTimeMs(startTime);
|
||||
}
|
||||
}
|
||||
|
||||
@ -379,15 +367,10 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
|
||||
// get the response
|
||||
long startTime = 0;
|
||||
if (this.isTraceEnabled) {
|
||||
startTime = System.nanoTime();
|
||||
}
|
||||
startTime = System.nanoTime();
|
||||
|
||||
this.statusCode = getConnResponseCode();
|
||||
|
||||
if (this.isTraceEnabled) {
|
||||
this.recvResponseTimeMs = elapsedTimeMs(startTime);
|
||||
}
|
||||
this.recvResponseTimeMs = elapsedTimeMs(startTime);
|
||||
|
||||
this.statusDescription = getConnResponseMessage();
|
||||
|
||||
@ -404,15 +387,11 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
return;
|
||||
}
|
||||
|
||||
if (this.isTraceEnabled) {
|
||||
startTime = System.nanoTime();
|
||||
}
|
||||
startTime = System.nanoTime();
|
||||
|
||||
if (statusCode >= HttpURLConnection.HTTP_BAD_REQUEST) {
|
||||
processStorageErrorResponse();
|
||||
if (this.isTraceEnabled) {
|
||||
this.recvResponseTimeMs += elapsedTimeMs(startTime);
|
||||
}
|
||||
this.recvResponseTimeMs += elapsedTimeMs(startTime);
|
||||
this.bytesReceived = this.connection.getHeaderFieldLong(HttpHeaderConfigurations.CONTENT_LENGTH, 0);
|
||||
} else {
|
||||
// consume the input stream to release resources
|
||||
@ -454,9 +433,7 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
LOG.debug("IO Error: ", ex);
|
||||
throw ex;
|
||||
} finally {
|
||||
if (this.isTraceEnabled) {
|
||||
this.recvResponseTimeMs += elapsedTimeMs(startTime);
|
||||
}
|
||||
this.recvResponseTimeMs += elapsedTimeMs(startTime);
|
||||
this.bytesReceived = totalBytesRead;
|
||||
}
|
||||
}
|
||||
@ -472,9 +449,6 @@ public class AbfsHttpOperation implements AbfsPerfLoggable {
|
||||
* @throws IOException if an error occurs.
|
||||
*/
|
||||
private HttpURLConnection openConnection() throws IOException {
|
||||
if (!isTraceEnabled) {
|
||||
return (HttpURLConnection) url.openConnection();
|
||||
}
|
||||
long start = System.nanoTime();
|
||||
try {
|
||||
return (HttpURLConnection) url.openConnection();
|
||||
|
@ -113,7 +113,7 @@ public final class TestAbfsPerfTracker {
|
||||
assertThat(latencyDetails).describedAs("AbfsPerfTracker should return non-null record").isNotNull();
|
||||
assertThat(latencyDetails).describedAs("Latency record should be in the correct format")
|
||||
.containsPattern("h=[^ ]* t=[^ ]* a=bogusFilesystemName c=bogusAccountName cr=oneOperationCaller"
|
||||
+ " ce=oneOperationCallee r=Succeeded l=[0-9]+ s=0 e= ci=[^ ]* ri=[^ ]* bs=0 br=0 m=GET"
|
||||
+ " ce=oneOperationCallee r=Succeeded l=[0-9]+ s=0 e= ci=[^ ]* ri=[^ ]* ct=[^ ]* st=[^ ]* rt=[^ ]* bs=0 br=0 m=GET"
|
||||
+ " u=http%3A%2F%2Fwww.microsoft.com%2FbogusFile");
|
||||
}
|
||||
|
||||
@ -154,7 +154,7 @@ public final class TestAbfsPerfTracker {
|
||||
assertThat(latencyDetails).describedAs("Latency record should be in the correct format")
|
||||
.containsPattern("h=[^ ]* t=[^ ]* a=bogusFilesystemName c=bogusAccountName cr=oneOperationCaller"
|
||||
+ " ce=oneOperationCallee r=Succeeded l=[0-9]+ ls=[0-9]+ lc=" + TEST_AGGREGATE_COUNT
|
||||
+ " s=0 e= ci=[^ ]* ri=[^ ]* bs=0 br=0 m=GET u=http%3A%2F%2Fwww.microsoft.com%2FbogusFile");
|
||||
+ " s=0 e= ci=[^ ]* ri=[^ ]* ct=[^ ]* st=[^ ]* rt=[^ ]* bs=0 br=0 m=GET u=http%3A%2F%2Fwww.microsoft.com%2FbogusFile");
|
||||
}
|
||||
|
||||
latencyDetails = abfsPerfTracker.getClientLatency();
|
||||
|
Loading…
x
Reference in New Issue
Block a user