io.opentracing.Span Maven / Gradle / Ivy
/*
* Copyright 2016-2018 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 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);
/**
* 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);
}