如何将 OpenTelemetry Java 代理生成的跟踪导出到 Google Cloud Trace?

hom*_*man 2 java google-cloud-trace open-telemetry

我有一个 Spring Boot 应用程序,我希望自动生成使用 OpenTelemetry Java 代理的跟踪,然后将这些跟踪上传到 Google Cloud Trace。

我已将以下代码添加到应用程序的入口点以发送跟踪:

OpenTelemetrySdk.builder()
    .setTracerProvider(
        SdkTracerProvider.builder()
            .addSpanProcessor(
                SimpleSpanProcessor.create(TraceExporter.createWithDefaultConfiguration())
            )
            .build()
    )
    .buildAndRegisterGlobal();
Run Code Online (Sandbox Code Playgroud)

...我正在使用以下系统属性运行我的应用程序:

-javaagent:path/to/opentelemetry-javaagent-all.jar \
-jar myapp.jar
Run Code Online (Sandbox Code Playgroud)

...但我不知道如何将两者联系起来。

我可以应用一些代理配置吗?就像是:

-Dotel.traces.exporter=google_cloud_trace
Run Code Online (Sandbox Code Playgroud)

hom*_*man 5

我最终解决了这个问题如下:

  1. 克隆GoogleCloudPlatform / opentelemetry-operations-java存储库

git克隆 git@github.com:GoogleCloudPlatform/opentelemetry-operations-java.git

  1. 构建exporter-auto项目

./gradlew clean :exporter-auto:shadowJar

  1. 将生成的jar复制exporter-auto/build/libs到我的目标项目中

  2. 使用以下参数运行应用程序:

-javaagent:path/to/opentelemetry-javaagent-all.jar
-Dotel.javaagent.experimental.extensions=[artifact-from-step-3].jar
-Dotel.traces.exporter=google_cloud_trace
-Dotel.metrics.exporter=none
-jar myapp.jar

注意:此设置不需要在目标代码库中进行任何显式代码更改。