Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

interop-test: add interop test open telemetry tracing flags #11674

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

YifeiZhuang
Copy link
Contributor

@YifeiZhuang YifeiZhuang commented Nov 7, 2024

This is a quick change to unblock benchmark test: go/c2p-w3c-benchmark
Usage:

revision1:
./run-test-client.sh --use_tls=false --use_open_telemetry_tracing=true --open_telemetry_propagator=w3c

./run-test-client.sh --use_tls=false --use_open_telemetry_tracing=true --open_telemetry_propagator=grpc-trace-bin

revision2:
use w3c: JAVA_OPTS=-Dotel.propagators=tracecontext ./run-test-client.sh --use_tls=false --use_open_telemetry_tracing=true
use grpc-trace-bin(do not set otel.propagator): ./run-test-client.sh --use_tls=false --use_open_telemetry_tracing=true

cc. @yashykt

@YifeiZhuang YifeiZhuang requested a review from apolcyn November 7, 2024 02:14
@YifeiZhuang YifeiZhuang requested a review from ejona86 November 7, 2024 20:11
@ejona86
Copy link
Member

ejona86 commented Nov 12, 2024

Why does this need to be committed to unblock a one-off benchmark? If we're wanting these in general for tracing testing, then we would need to update the cross-language specification.

I do also wonder if we should use the otel-defined environment variables for specifying the propagator instead of making something of our own.

Given the interplay between otel metrics and tracing, it seems we should maybe have a flag to enable otel and then use otel-defined variables to configure which parts of otel are being used.

@YifeiZhuang
Copy link
Contributor Author

@apolcyn, @yashykt and I had discussion. For one-off benchmark test, it would be easier to run an existing benchmark framework that uses interop test client here. The future work of otel tracing interop test (go/grpc-otel-tracing-acceptance-criteria) is likely different, i.e. it would require the test server to return a response on payload, and it would require the client to add a new a new test. This one is more about just enable opentelemetry tracing. I think it does not hurt to add one in Java for quick experimentation of C2P communication with otel tracing.

Given the interplay between otel metrics and tracing, it seems we should maybe have a flag to enable otel and then use otel-defined variables to configure which parts of otel are being used.

It's probably a good idea. Let me try using the environmental variable configuration.

@ejona86
Copy link
Member

ejona86 commented Nov 13, 2024

it would be easier to run an existing benchmark framework that uses interop test client here

But what about that needs this change to be committed?

@apolcyn
Copy link
Contributor

apolcyn commented Nov 13, 2024

But what about that needs this change to be committed?

Personally I am ok without this being committed. Committing will likely be useful in the future if/when we turn it on in continuous tests, or if we plan to do a number of manual experiments with this. But I'm fine to wait for that, too.

@YifeiZhuang
Copy link
Contributor Author

But what about that needs this change to be committed?

Personally I am ok without this being committed. Committing will likely be useful in the future if/when we turn it on in continuous tests, or if we plan to do a number of manual experiments with this. But I'm fine to wait for that, too.

Okay. Sounds good.
I somehow remember you said that it needs to be checked in to g3. If we do not commit any code to master, it's easier.
Anyways, I published another revision that uses autoSDK. See PR description of the new usage. But either way.

Copy link
Member

@ejona86 ejona86 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems close to the right shape. We'd still want it defined cross-language, though.

@@ -216,6 +222,8 @@ void parseArgs(String[] args) throws Exception {
soakResponseSize = Integer.parseInt(value);
} else if ("additional_metadata".equals(key)) {
additionalMetadata = value;
} else if ("use_open_telemetry_tracing".equals(key)) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is more than just tracing, so I thought it'd be named more like "use_open_telemetry"

@@ -57,6 +60,8 @@ public void set(@Nullable Metadata carrier, String key, String value) {
}

void set(@Nullable Metadata carrier, String key, byte[] value) {
logger.log(Level.FINE, "Setting binary trace header key={0} value={1}",
new Object[]{key, Arrays.toString(value)});
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This toString() is performed even when logging is disabled. Does Arrays.asList() work?

.sdk(openTelemetrySdk);
InternalGrpcOpenTelemetry.enableTracing(grpcOpentelemetryBuilder, true);
GrpcOpenTelemetry grpcOpenTelemetry = grpcOpentelemetryBuilder.build();
// Disabling census-tracing is necessary to avoid trace ID mismatches.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The auto-applying is still causing trouble... This is a symptom of larger issues. It's okay for a while, but our users may have to deal with the same.

OpenTelemetrySdk openTelemetrySdk = AutoConfiguredOpenTelemetrySdk.builder()
.addPropagatorCustomizer((reader, config) -> {
if (config.getString("otel.propagators") == null) {
return GrpcTraceBinContextPropagator.defaultInstance();
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should set up the SPI for GrpcTraceBinContextPropagator.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants