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

io.opentracing.Span Maven / Gradle / Ivy

/*
 * Copyright 2016-2019 The OpenTracing Authors
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
 * in compliance with the License. You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under the License
 * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
 * or implied. See the License for the specific language governing permissions and limitations under
 * the License.
 */
package io.opentracing;

import io.opentracing.tag.Tag;
import java.util.Map;

/**
 * {@link Span} represents the OpenTracing specification's Span contract.
 *
 * @see Scope
 * @see ScopeManager
 * @see Tracer.SpanBuilder#start()
 * @see Tracer.SpanBuilder#startActive()
 */
public interface Span {
    /**
     * Retrieve the associated SpanContext.
     *
     * This may be called at any time, including after calls to finish().
     *
     * @return the SpanContext that encapsulates Span state that should propagate across process boundaries.
     */
    SpanContext context();

    /**
     * Set a key:value tag on the Span.
     */
    Span setTag(String key, String value);

    /** Same as {@link #setTag(String, String)}, but for boolean values. */
    Span setTag(String key, boolean value);

    /** Same as {@link #setTag(String, String)}, but for numeric values. */
    Span setTag(String key, Number value);

    /** Same as {@link #setTag(String, String)}, but with using Tag. */
     Span setTag(Tag tag, T value);

    /**
     * Log key:value pairs to the Span with the current walltime timestamp.
     *
     * 

CAUTIONARY NOTE: not all Tracer implementations support key:value log fields end-to-end. * Caveat emptor. * *

A contrived example (using Guava, which is not required): *


     span.log(
     ImmutableMap.Builder()
     .put("event", "soft error")
     .put("type", "cache timeout")
     .put("waited.millis", 1500)
     .build());
     
* * @param fields key:value log fields. Tracer implementations should support String, numeric, and boolean values; * some may also support arbitrary Objects. * @return the Span, for chaining * @see Span#log(String) */ Span log(Map fields); /** * Like log(Map<String, Object>), but with an explicit timestamp. * *

CAUTIONARY NOTE: not all Tracer implementations support key:value log fields end-to-end. * Caveat emptor. * * @param timestampMicroseconds The explicit timestamp for the log record. Must be greater than or equal to the * Span's start timestamp. * @param fields key:value log fields. Tracer implementations should support String, numeric, and boolean values; * some may also support arbitrary Objects. * @return the Span, for chaining * @see Span#log(long, String) */ Span log(long timestampMicroseconds, Map fields); /** * Record an event at the current walltime timestamp. * * Shorthand for * *


     span.log(Collections.singletonMap("event", event));
     
* * @param event the event value; often a stable identifier for a moment in the Span lifecycle * @return the Span, for chaining */ Span log(String event); /** * Record an event at a specific timestamp. * * Shorthand for * *

     span.log(timestampMicroseconds, Collections.singletonMap("event", event));
     
* * @param timestampMicroseconds The explicit timestamp for the log record. Must be greater than or equal to the * Span's start timestamp. * @param event the event value; often a stable identifier for a moment in the Span lifecycle * @return the Span, for chaining */ Span log(long timestampMicroseconds, String event); /** * Sets a baggage item in the Span (and its SpanContext) as a key/value pair. * * Baggage enables powerful distributed context propagation functionality where arbitrary application data can be * carried along the full path of request execution throughout the system. * * Note 1: Baggage is only propagated to the future (recursive) children of this SpanContext. * * Note 2: Baggage is sent in-band with every subsequent local and remote calls, so this feature must be used with * care. * * @return this Span instance, for chaining */ Span setBaggageItem(String key, String value); /** * @return the value of the baggage item identified by the given key, or null if no such item could be found */ String getBaggageItem(String key); /** * Sets the string name for the logical operation this span represents. * * @return this Span instance, for chaining */ Span setOperationName(String operationName); /** * Sets the end timestamp to now and records the span. * *

With the exception of calls to {@link #context}, this should be the last call made to the span instance. * Future calls to {@link #finish} are defined as noops, and future calls to methods other than {@link #context} * lead to undefined behavior. * * @see Span#context() */ void finish(); /** * Sets an explicit end timestamp and records the span. * *

With the exception of calls to Span.context(), this should be the last call made to the span instance, and to * do otherwise leads to undefined behavior. * * @param finishMicros an explicit finish time, in microseconds since the epoch * * @see Span#context() */ void finish(long finishMicros); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy