Код: Выделить всё
@Bean
public static OpenTelemetry openTelemetry() {
Resource resource = Resource.getDefault();
SdkTracerProvider sdkTracerProvider = SdkTracerProvider.builder()
.addSpanProcessor(SimpleSpanProcessor.create(LoggingSpanExporter.create()))
.setResource(resource)
.build();
SdkMeterProvider sdkMeterProvider = SdkMeterProvider.builder()
.registerMetricReader(PeriodicMetricReader.builder(LoggingMetricExporter.create()).build())
.setResource(resource)
.build();
SdkLoggerProvider sdkLoggerProvider = SdkLoggerProvider.builder()
.addLogRecordProcessor(BatchLogRecordProcessor.builder(SystemOutLogRecordExporter.create()).build())
.setResource(resource)
.build();
OpenTelemetry openTelemetry = OpenTelemetrySdk.builder()
.setTracerProvider(sdkTracerProvider)
.setMeterProvider(sdkMeterProvider)
.setLoggerProvider(sdkLoggerProvider)
.setPropagators(ContextPropagators.create(TextMapPropagator.composite(W3CTraceContextPropagator.getInstance(), W3CBaggagePropagator.getInstance())))
.buildAndRegisterGlobal();
return openTelemetry;
}
Код: Выделить всё
private Tracer tracer;
private OpenTelemetry openTelemetry;
AccountInfoController(OpenTelemetry openTelemetry) {
tracer = openTelemetry.getTracer(AccountInfoController.class.getName(), "0.1.0");
}
Код: Выделить всё
Span span = tracer.spanBuilder(spanName).startSpan();
Код: Выделить всё
Context.current().with(parentSpan).makeCurrent();
Span serviceSpan = tracer.spanBuilder(spanName)
.setParent(Context.current().with(Span.current()))
.startSpan();
Однако я получаю идентификатор трассировки, повторяющийся после 10 итераций.
Как генерировать уникальные идентификаторы трассировки?
Подробнее здесь: https://stackoverflow.com/questions/788 ... d-after-10