All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.opentelemetry.sdk.trace.export.SpanExporter Maven / Gradle / Ivy

/*
 * Copyright The OpenTelemetry Authors
 * SPDX-License-Identifier: Apache-2.0
 */

package io.opentelemetry.sdk.trace.export;

import io.opentelemetry.sdk.common.CompletableResultCode;
import io.opentelemetry.sdk.trace.SdkTracerProvider;
import io.opentelemetry.sdk.trace.SpanProcessor;
import io.opentelemetry.sdk.trace.data.SpanData;
import java.io.Closeable;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;
import java.util.concurrent.TimeUnit;

/**
 * An interface that allows different tracing services to export recorded data for sampled spans in
 * their own format.
 *
 * 

To export data this MUST be register to the {@code TracerSdk} using a {@link * SimpleSpanProcessor} or a {@code BatchSampledSpansProcessor}. */ public interface SpanExporter extends Closeable { /** * Returns a {@link SpanExporter} which delegates all exports to the {@code exporters} in order. * *

Can be used to export to multiple backends using the same {@link SpanProcessor} like a * {@link SimpleSpanProcessor} or a {@link BatchSpanProcessor}. */ static SpanExporter composite(SpanExporter... exporters) { return composite(Arrays.asList(exporters)); } /** * Returns a {@link SpanExporter} which delegates all exports to the {@code exporters} in order. * *

Can be used to export to multiple backends using the same {@link SpanProcessor} like a * {@link SimpleSpanProcessor} or a {@link BatchSpanProcessor}. */ static SpanExporter composite(Iterable exporters) { List exportersList = new ArrayList<>(); for (SpanExporter exporter : exporters) { exportersList.add(exporter); } if (exportersList.isEmpty()) { return NoopSpanExporter.getInstance(); } if (exportersList.size() == 1) { return exportersList.get(0); } return MultiSpanExporter.create(exportersList); } /** * Called to export sampled {@code Span}s. Note that export operations can be performed * simultaneously depending on the type of span processor being used. However, the {@link * BatchSpanProcessor} will ensure that only one export can occur at a time. * * @param spans the collection of sampled Spans to be exported. * @return the result of the export, which is often an asynchronous operation. */ CompletableResultCode export(Collection spans); /** * Exports the collection of sampled {@code Span}s that have not yet been exported. Note that * export operations can be performed simultaneously depending on the type of span processor being * used. However, the {@link BatchSpanProcessor} will ensure that only one export can occur at a * time. * * @return the result of the flush, which is often an asynchronous operation. */ CompletableResultCode flush(); /** * Called when {@link SdkTracerProvider#shutdown()} is called, if this {@code SpanExporter} is * registered to a {@link SdkTracerProvider} object. * * @return a {@link CompletableResultCode} which is completed when shutdown completes. */ CompletableResultCode shutdown(); /** Closes this {@link SpanExporter}, releasing any resources. */ @Override default void close() { shutdown().join(10, TimeUnit.SECONDS); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy