HDDS-1152. Add trace information for the client side of the datanode writes
Contributed by Elek, Marton.
This commit is contained in:
parent
5c1f946071
commit
3aa0a57ea0
|
@ -37,6 +37,9 @@ import org.apache.hadoop.ozone.OzoneConfigKeys;
|
||||||
import org.apache.hadoop.ozone.OzoneConsts;
|
import org.apache.hadoop.ozone.OzoneConsts;
|
||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
import org.apache.hadoop.util.Time;
|
import org.apache.hadoop.util.Time;
|
||||||
|
|
||||||
|
import io.opentracing.Scope;
|
||||||
|
import io.opentracing.util.GlobalTracer;
|
||||||
import org.apache.ratis.thirdparty.io.grpc.ManagedChannel;
|
import org.apache.ratis.thirdparty.io.grpc.ManagedChannel;
|
||||||
import org.apache.ratis.thirdparty.io.grpc.Status;
|
import org.apache.ratis.thirdparty.io.grpc.Status;
|
||||||
import org.apache.ratis.thirdparty.io.grpc.netty.GrpcSslContexts;
|
import org.apache.ratis.thirdparty.io.grpc.netty.GrpcSslContexts;
|
||||||
|
@ -288,17 +291,20 @@ public class XceiverClientGrpc extends XceiverClientSpi {
|
||||||
public XceiverClientReply sendCommandAsync(
|
public XceiverClientReply sendCommandAsync(
|
||||||
ContainerCommandRequestProto request)
|
ContainerCommandRequestProto request)
|
||||||
throws IOException, ExecutionException, InterruptedException {
|
throws IOException, ExecutionException, InterruptedException {
|
||||||
XceiverClientReply asyncReply =
|
try (Scope scope = GlobalTracer.get()
|
||||||
sendCommandAsync(request, pipeline.getFirstNode());
|
.buildSpan("XceiverClientGrpc." + request.getCmdType().name())
|
||||||
|
.startActive(true)) {
|
||||||
// TODO : for now make this API sync in nature as async requests are
|
XceiverClientReply asyncReply =
|
||||||
// served out of order over XceiverClientGrpc. This needs to be fixed
|
sendCommandAsync(request, pipeline.getFirstNode());
|
||||||
// if this API is to be used for I/O path. Currently, this is not
|
// TODO : for now make this API sync in nature as async requests are
|
||||||
// used for Read/Write Operation but for tests.
|
// served out of order over XceiverClientGrpc. This needs to be fixed
|
||||||
if (!HddsUtils.isReadOnly(request)) {
|
// if this API is to be used for I/O path. Currently, this is not
|
||||||
asyncReply.getResponse().get();
|
// used for Read/Write Operation but for tests.
|
||||||
|
if (!HddsUtils.isReadOnly(request)) {
|
||||||
|
asyncReply.getResponse().get();
|
||||||
|
}
|
||||||
|
return asyncReply;
|
||||||
}
|
}
|
||||||
return asyncReply;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private XceiverClientReply sendCommandAsync(
|
private XceiverClientReply sendCommandAsync(
|
||||||
|
|
|
@ -22,6 +22,9 @@ import com.google.common.base.Preconditions;
|
||||||
import org.apache.hadoop.hdds.HddsUtils;
|
import org.apache.hadoop.hdds.HddsUtils;
|
||||||
import org.apache.hadoop.hdds.protocol.datanode.proto.ContainerProtos;
|
import org.apache.hadoop.hdds.protocol.datanode.proto.ContainerProtos;
|
||||||
import org.apache.hadoop.hdds.security.x509.SecurityConfig;
|
import org.apache.hadoop.hdds.security.x509.SecurityConfig;
|
||||||
|
|
||||||
|
import io.opentracing.Scope;
|
||||||
|
import io.opentracing.util.GlobalTracer;
|
||||||
import org.apache.ratis.grpc.GrpcTlsConfig;
|
import org.apache.ratis.grpc.GrpcTlsConfig;
|
||||||
import org.apache.ratis.proto.RaftProtos;
|
import org.apache.ratis.proto.RaftProtos;
|
||||||
import org.apache.ratis.protocol.RaftRetryFailureException;
|
import org.apache.ratis.protocol.RaftRetryFailureException;
|
||||||
|
@ -191,15 +194,20 @@ public final class XceiverClientRatis extends XceiverClientSpi {
|
||||||
|
|
||||||
private CompletableFuture<RaftClientReply> sendRequestAsync(
|
private CompletableFuture<RaftClientReply> sendRequestAsync(
|
||||||
ContainerCommandRequestProto request) {
|
ContainerCommandRequestProto request) {
|
||||||
ContainerCommandRequestProto finalPayload =
|
try (Scope scope = GlobalTracer.get()
|
||||||
ContainerCommandRequestProto.newBuilder(request)
|
.buildSpan("XceiverClientRatis." + request.getCmdType().name())
|
||||||
.setTraceID(TracingUtil.exportCurrentSpan())
|
.startActive(true)) {
|
||||||
.build();
|
ContainerCommandRequestProto finalPayload =
|
||||||
boolean isReadOnlyRequest = HddsUtils.isReadOnly(finalPayload);
|
ContainerCommandRequestProto.newBuilder(request)
|
||||||
ByteString byteString = finalPayload.toByteString();
|
.setTraceID(TracingUtil.exportCurrentSpan())
|
||||||
LOG.debug("sendCommandAsync {} {}", isReadOnlyRequest, finalPayload);
|
.build();
|
||||||
return isReadOnlyRequest ? getClient().sendReadOnlyAsync(() -> byteString) :
|
boolean isReadOnlyRequest = HddsUtils.isReadOnly(finalPayload);
|
||||||
getClient().sendAsync(() -> byteString);
|
ByteString byteString = finalPayload.toByteString();
|
||||||
|
LOG.debug("sendCommandAsync {} {}", isReadOnlyRequest, finalPayload);
|
||||||
|
return isReadOnlyRequest ?
|
||||||
|
getClient().sendReadOnlyAsync(() -> byteString) :
|
||||||
|
getClient().sendAsync(() -> byteString);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// gets the minimum log index replicated to all servers
|
// gets the minimum log index replicated to all servers
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one or more
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
* contributor license agreements. See the NOTICE file distributed with this
|
* contributor license agreements. See the NOTICE file distributed with this
|
||||||
|
@ -614,9 +615,13 @@ public final class RandomKeyGenerator implements Callable<Void> {
|
||||||
.update(keyCreationDuration);
|
.update(keyCreationDuration);
|
||||||
keyCreationTime.getAndAdd(keyCreationDuration);
|
keyCreationTime.getAndAdd(keyCreationDuration);
|
||||||
long keyWriteStart = System.nanoTime();
|
long keyWriteStart = System.nanoTime();
|
||||||
os.write(keyValue);
|
try (Scope writeScope = GlobalTracer.get()
|
||||||
os.write(randomValue);
|
.buildSpan("writeKeyData")
|
||||||
os.close();
|
.startActive(true)) {
|
||||||
|
os.write(keyValue);
|
||||||
|
os.write(randomValue);
|
||||||
|
os.close();
|
||||||
|
}
|
||||||
|
|
||||||
long keyWriteDuration = System.nanoTime() - keyWriteStart;
|
long keyWriteDuration = System.nanoTime() - keyWriteStart;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue