Copyright | (c) Ian Duncan 2021 |
---|---|
License | BSD-3 |
Maintainer | Ian Duncan |
Stability | experimental |
Portability | non-portable (GHC extensions) |
Safe Haskell | None |
Language | Haskell2010 |
Traces track the progression of a single request, called a trace, as it is handled by services that make up an application. The request may be initiated by a user or an application. Distributed tracing is a form of tracing that traverses process, network and security boundaries. Each unit of work in a trace is called a span; a trace is a tree of spans. Spans are objects that represent the work being done by individual services or components involved in a request as it flows through a system. A span contains a span context, which is a set of globally unique identifiers that represent the unique request that each span is a part of. A span provides Request, Error and Duration (RED) metrics that can be used to debug availability as well as performance issues.
A trace contains a single root span which encapsulates the end-to-end latency for the entire request. You can think of this as a single logical operation, such as clicking a button in a web application to add a product to a shopping cart. The root span would measure the time it took from an end-user clicking that button to the operation being completed or failing (so, the item is added to the cart or some error occurs) and the result being displayed to the user. A trace is comprised of the single root span and any number of child spans, which represent operations taking place as part of the request. Each span contains metadata about the operation, such as its name, start and end timestamps, attributes, events, and status.
To create and manage Span
s in OpenTelemetry, the OpenTelemetry API provides the tracer interface. This object is responsible for tracking the active span in your process, and allows you to access the current span in order to perform operations on it such as adding attributes, events, and finishing it when the work it tracks is complete. One or more tracer objects can be created in a process through the tracer provider, a factory interface that allows for multiple Tracer
s to be instantiated in a single process with different options.
Generally, the lifecycle of a span resembles the following:
A request is received by a service. The span context is extracted from the request headers, if it exists. A new span is created as a child of the extracted span context; if none exists, a new root span is created. The service handles the request. Additional attributes and events are added to the span that are useful for understanding the context of the request, such as the hostname of the machine handling the request, or customer identifiers. New spans may be created to represent work being done by sub-components of the service. When the service makes a remote call to another service, the current span context is serialized and forwarded to the next service by injecting the span context into the headers or message envelope. The work being done by the service completes, successfully or not. The span status is appropriately set, and the span is marked finished. For more information, see the traces specification, which covers concepts including: trace, span, parent/child relationship, span context, attributes, events and links.
This module implements eveything required to conform to the trace & span public interface described by the OpenTelemetry specification.
See OpenTelemetry.Trace.Monad for an implementation that's generally easier to use in idiomatic Haskell.
Synopsis
- data TracerProvider
- createTracerProvider :: MonadIO m => [Processor] -> TracerProviderOptions -> m TracerProvider
- shutdownTracerProvider :: MonadIO m => TracerProvider -> m ()
- forceFlushTracerProvider :: MonadIO m => TracerProvider -> Maybe Int -> m FlushResult
- getTracerProviderResources :: TracerProvider -> MaterializedResources
- getTracerProviderPropagators :: TracerProvider -> Propagator Context RequestHeaders ResponseHeaders
- getGlobalTracerProvider :: MonadIO m => m TracerProvider
- setGlobalTracerProvider :: MonadIO m => TracerProvider -> m ()
- emptyTracerProviderOptions :: TracerProviderOptions
- data TracerProviderOptions = TracerProviderOptions {
- tracerProviderOptionsIdGenerator :: IdGenerator
- tracerProviderOptionsSampler :: Sampler
- tracerProviderOptionsResources :: MaterializedResources
- tracerProviderOptionsAttributeLimits :: AttributeLimits
- tracerProviderOptionsSpanLimits :: SpanLimits
- tracerProviderOptionsPropagators :: Propagator Context RequestHeaders ResponseHeaders
- tracerProviderOptionsLogger :: Log Text -> IO ()
- data Tracer
- tracerName :: Tracer -> InstrumentationLibrary
- class HasTracer s where
- makeTracer :: TracerProvider -> InstrumentationLibrary -> TracerOptions -> Tracer
- getTracer :: MonadIO m => TracerProvider -> InstrumentationLibrary -> TracerOptions -> m Tracer
- getImmutableSpanTracer :: ImmutableSpan -> Tracer
- getTracerTracerProvider :: Tracer -> TracerProvider
- data InstrumentationLibrary = InstrumentationLibrary {
- libraryName :: !Text
- libraryVersion :: !Text
- newtype TracerOptions = TracerOptions {}
- tracerOptions :: TracerOptions
- data Span
- data ImmutableSpan = ImmutableSpan {}
- data SpanContext = SpanContext {
- traceFlags :: TraceFlags
- isRemote :: Bool
- traceId :: TraceId
- spanId :: SpanId
- traceState :: TraceState
- data TraceFlags
- traceFlagsValue :: TraceFlags -> Word8
- traceFlagsFromWord8 :: Word8 -> TraceFlags
- defaultTraceFlags :: TraceFlags
- isSampled :: TraceFlags -> Bool
- setSampled :: TraceFlags -> TraceFlags
- unsetSampled :: TraceFlags -> TraceFlags
- inSpan :: (MonadUnliftIO m, HasCallStack) => Tracer -> Text -> SpanArguments -> m a -> m a
- inSpan' :: (MonadUnliftIO m, HasCallStack) => Tracer -> Text -> SpanArguments -> (Span -> m a) -> m a
- inSpan'' :: (MonadUnliftIO m, HasCallStack) => Tracer -> CallStack -> Text -> SpanArguments -> (Span -> m a) -> m a
- createSpan :: (MonadIO m, HasCallStack) => Tracer -> Context -> Text -> SpanArguments -> m Span
- createSpanWithoutCallStack :: MonadIO m => Tracer -> Context -> Text -> SpanArguments -> m Span
- wrapSpanContext :: SpanContext -> Span
- data SpanKind
- defaultSpanArguments :: SpanArguments
- data SpanArguments = SpanArguments {}
- data NewLink = NewLink {
- linkContext :: !SpanContext
- linkAttributes :: [(Text, Attribute)]
- data Link = Link {}
- data Event = Event {}
- data NewEvent = NewEvent {}
- addEvent :: MonadIO m => Span -> NewEvent -> m ()
- updateName :: MonadIO m => Span -> Text -> m ()
- addAttribute :: (MonadIO m, ToAttribute a) => Span -> Text -> a -> m ()
- addAttributes :: MonadIO m => Span -> [(Text, Attribute)] -> m ()
- spanGetAttributes :: MonadIO m => Span -> m Attributes
- data Attribute
- class ToAttribute a where
- toAttribute :: a -> Attribute
- data PrimitiveAttribute
- class ToPrimitiveAttribute a where
- recordException :: (MonadIO m, Exception e) => Span -> [(Text, Attribute)] -> Maybe Timestamp -> e -> m ()
- setStatus :: MonadIO m => Span -> SpanStatus -> m ()
- data SpanStatus
- endSpan :: MonadIO m => Span -> Maybe Timestamp -> m ()
- getSpanContext :: MonadIO m => Span -> m SpanContext
- isRecording :: MonadIO m => Span -> m Bool
- isValid :: SpanContext -> Bool
- spanIsRemote :: MonadIO m => Span -> m Bool
- data Timestamp
- getTimestamp :: MonadIO m => m Timestamp
- timestampNanoseconds :: Timestamp -> Word64
- unsafeReadSpan :: MonadIO m => Span -> m ImmutableSpan
- whenSpanIsRecording :: MonadIO m => Span -> m () -> m ()
- data SpanLimits = SpanLimits {}
- defaultSpanLimits :: SpanLimits
- bracketError :: MonadUnliftIO m => m a -> (Maybe SomeException -> a -> m b) -> (a -> m c) -> m c
TracerProvider
operations
data TracerProvider Source #
Tracer
s can be created from a TracerProvider
.
createTracerProvider :: MonadIO m => [Processor] -> TracerProviderOptions -> m TracerProvider Source #
Initialize a new tracer provider
You should generally use getGlobalTracerProvider
for most applications.
shutdownTracerProvider :: MonadIO m => TracerProvider -> m () Source #
This method provides a way for provider to do any cleanup required.
This will also trigger shutdowns on all internal processors.
Since: 0.0.1.0
forceFlushTracerProvider Source #
:: MonadIO m | |
=> TracerProvider | |
-> Maybe Int | Optional timeout in microseconds, defaults to 5,000,000 (5s) |
-> m FlushResult | Result that denotes whether the flush action succeeded, failed, or timed out. |
This method provides a way for provider to immediately export all spans that have not yet been exported for all the internal processors.
getTracerProviderPropagators :: TracerProvider -> Propagator Context RequestHeaders ResponseHeaders Source #
getGlobalTracerProvider :: MonadIO m => m TracerProvider Source #
Access the globally configured TracerProvider
. Once the
the global tracer provider is initialized via the OpenTelemetry SDK,
Tracer
s created from this TracerProvider
will export spans to their
configured exporters. Prior to that, any Tracer
s acquired from the
uninitialized TracerProvider
will create no-op spans.
Since: 0.0.1.0
setGlobalTracerProvider :: MonadIO m => TracerProvider -> m () Source #
Overwrite the globally configured TracerProvider
.
Tracer
s acquired from the previously installed TracerProvider
will continue to use that TracerProvider
s configured span processors,
exporters, and other settings.
Since: 0.0.1.0
emptyTracerProviderOptions :: TracerProviderOptions Source #
Options for creating a TracerProvider
with invalid ids, no resources, default limits, and no propagators.
In effect, tracing is a no-op when using this configuration.
Since: 0.0.1.0
data TracerProviderOptions Source #
Tracer
operations
tracerName :: Tracer -> InstrumentationLibrary Source #
Get the name of the Tracer
Since: 0.0.10
makeTracer :: TracerProvider -> InstrumentationLibrary -> TracerOptions -> Tracer Source #
getTracer :: MonadIO m => TracerProvider -> InstrumentationLibrary -> TracerOptions -> m Tracer Source #
Deprecated: use makeTracer
data InstrumentationLibrary Source #
An identifier for the library that provides the instrumentation for a given Instrumented Library. Instrumented Library and Instrumentation Library may be the same library if it has built-in OpenTelemetry instrumentation.
The inspiration of the OpenTelemetry project is to make every library and application observable out of the box by having them call OpenTelemetry API directly. However, many libraries will not have such integration, and as such there is a need for a separate library which would inject such calls, using mechanisms such as wrapping interfaces, subscribing to library-specific callbacks, or translating existing telemetry into the OpenTelemetry model.
A library that enables OpenTelemetry observability for another library is called an Instrumentation Library.
An instrumentation library should be named to follow any naming conventions of the instrumented library (e.g. middleware
for a web framework).
If there is no established name, the recommendation is to prefix packages with "hs-opentelemetry-instrumentation", followed by the instrumented library name itself.
In general, you can initialize the instrumentation library like so:
import qualified Data.Text as T import Data.Version (showVersion) import Paths_your_package_name instrumentationLibrary :: InstrumentationLibrary instrumentationLibrary = InstrumentationLibrary { libraryName = "your_package_name" , libraryVersion = T.pack $ showVersion version }
InstrumentationLibrary | |
|
Instances
newtype TracerOptions Source #
Tracer configuration options.
TracerOptions | |
|
tracerOptions :: TracerOptions Source #
Default Tracer options
Span operations
A Span
is the fundamental type you'll work with to trace your systems.
A span is a single piece of instrumentation from a single location in your code or infrastructure. A span represents a single "unit of work" done by a service. Each span contains several key pieces of data:
- A service name identifying the service the span is from
- A name identifying the role of the span (like function or method name)
- A timestamp that corresponds to the start of the span
- A duration that describes how long that unit of work took to complete
- An ID that uniquely identifies the span
- A trace ID identifying which trace the span belongs to
- A parent ID representing the parent span that called this span. (There is no parent ID for the root span of a given trace, which denotes that it's the start of the trace.)
- Any additional metadata that might be helpful.
- Zero or more links to related spans. Links can be useful for connecting causal relationships between things like web requests that enqueue asynchronous tasks to be processed.
- Events, which denote a point in time occurrence. These can be useful for recording data about a span such as when an exception was thrown, or to emit structured logs into the span tree.
A trace is made up of multiple spans. Tracing vendors such as Zipkin, Jaeger, Honeycomb, Datadog, Lightstep, etc. use the metadata from each span to reconstruct the relationships between them and generate a trace diagram.
data ImmutableSpan Source #
The frozen representation of a Span
that originates from the currently running process.
Only Processor
s and Exporter
s should use rely on this interface.
ImmutableSpan | |
|
Instances
Show ImmutableSpan Source # | |
Defined in OpenTelemetry.Internal.Trace.Types showsPrec :: Int -> ImmutableSpan -> ShowS # show :: ImmutableSpan -> String # showList :: [ImmutableSpan] -> ShowS # |
data SpanContext Source #
A SpanContext
represents the portion of a Span
which must be serialized and
propagated along side of a distributed context. SpanContext
s are immutable.
SpanContext | |
|
Instances
Eq SpanContext Source # | |
Defined in OpenTelemetry.Internal.Trace.Types (==) :: SpanContext -> SpanContext -> Bool # (/=) :: SpanContext -> SpanContext -> Bool # | |
Show SpanContext Source # | |
Defined in OpenTelemetry.Internal.Trace.Types showsPrec :: Int -> SpanContext -> ShowS # show :: SpanContext -> String # showList :: [SpanContext] -> ShowS # |
W3c Trace flags
data TraceFlags Source #
Contain details about the trace. Unlike TraceState values, TraceFlags are present in all traces. The current version of the specification only supports a single flag called sampled.
Instances
Eq TraceFlags Source # | |
Defined in OpenTelemetry.Common (==) :: TraceFlags -> TraceFlags -> Bool # (/=) :: TraceFlags -> TraceFlags -> Bool # | |
Ord TraceFlags Source # | |
Defined in OpenTelemetry.Common compare :: TraceFlags -> TraceFlags -> Ordering # (<) :: TraceFlags -> TraceFlags -> Bool # (<=) :: TraceFlags -> TraceFlags -> Bool # (>) :: TraceFlags -> TraceFlags -> Bool # (>=) :: TraceFlags -> TraceFlags -> Bool # max :: TraceFlags -> TraceFlags -> TraceFlags # min :: TraceFlags -> TraceFlags -> TraceFlags # | |
Show TraceFlags Source # | |
Defined in OpenTelemetry.Common showsPrec :: Int -> TraceFlags -> ShowS # show :: TraceFlags -> String # showList :: [TraceFlags] -> ShowS # |
traceFlagsValue :: TraceFlags -> Word8 Source #
Get the current bitmask for the TraceFlags
, useful for serialization purposes.
traceFlagsFromWord8 :: Word8 -> TraceFlags Source #
Create a TraceFlags
, from an arbitrary Word8
. Note that for backwards-compatibility
reasons, no checking is performed to determine whether the TraceFlags
bitmask provided
is valid.
defaultTraceFlags :: TraceFlags Source #
TraceFlags with the sampled
flag not set. This means that it is up to the
sampling configuration to decide whether or not to sample the trace.
isSampled :: TraceFlags -> Bool Source #
Will the trace associated with this TraceFlags
value be sampled?
setSampled :: TraceFlags -> TraceFlags Source #
Set the sampled
flag on the TraceFlags
unsetSampled :: TraceFlags -> TraceFlags Source #
Unset the sampled
flag on the TraceFlags
. This means that the
application may choose whether or not to emit this Trace.
Creating Span
s
:: (MonadUnliftIO m, HasCallStack) | |
=> Tracer | |
-> Text | The name of the span. This may be updated later via |
-> SpanArguments | Additional options for creating the span, such as |
-> m a | The action to perform. |
-> m a |
The simplest function for annotating code with trace information.
Since: 0.0.1.0
:: (MonadUnliftIO m, HasCallStack) | |
=> Tracer | |
-> Text | The name of the span. This may be updated later via |
-> SpanArguments | |
-> (Span -> m a) | |
-> m a |
:: (MonadUnliftIO m, HasCallStack) | |
=> Tracer | |
-> CallStack | Record the location of the span in the codebase using the provided callstack for source location info. |
-> Text | The name of the span. This may be updated later via |
-> SpanArguments | |
-> (Span -> m a) | |
-> m a |
:: (MonadIO m, HasCallStack) | |
=> Tracer |
|
-> Context | Context, potentially containing a parent span. If no existing parent (or context) exists,
you can use |
-> Text | Span name |
-> SpanArguments | Additional span information |
-> m Span | The created span. |
createSpanWithoutCallStack Source #
:: MonadIO m | |
=> Tracer |
|
-> Context | Context, potentially containing a parent span. If no existing parent (or context) exists,
you can use |
-> Text | Span name |
-> SpanArguments | Additional span information |
-> m Span | The created span. |
The same thing as createSpan
, except that it does not have a HasCallStack
constraint.
wrapSpanContext :: SpanContext -> Span Source #
SpanKind
describes the relationship between the Span
, its parents, and its children in a Trace. SpanKind
describes two independent properties that benefit tracing systems during analysis.
The first property described by SpanKind
reflects whether the Span
is a remote child or parent. Span
s with a remote parent are interesting because they are sources of external load. Spans with a remote child are interesting because they reflect a non-local system dependency.
The second property described by SpanKind
reflects whether a child Span
represents a synchronous call. When a child span is synchronous, the parent is expected to wait for it to complete under ordinary circumstances. It can be useful for tracing systems to know this property, since synchronous Span
s may contribute to the overall trace latency. Asynchronous scenarios can be remote or local.
In order for SpanKind
to be meaningful, callers SHOULD arrange that a single Span
does not serve more than one purpose. For example, a server-side span SHOULD NOT be used directly as the parent of another remote span. As a simple guideline, instrumentation should create a new Span
prior to extracting and serializing the SpanContext
for a remote call.
To summarize the interpretation of these kinds
SpanKind | Synchronous | Asynchronous | Remote Incoming | Remote Outgoing |
---|---|---|---|---|
Client | yes | yes | ||
Server | yes | yes | ||
Producer | yes | maybe | ||
Consumer | yes | maybe | ||
Internal |
Server | Indicates that the span covers server-side handling of a synchronous RPC or other remote request.
This span is the child of a remote |
Client | Indicates that the span describes a synchronous request to some remote service.
This span is the parent of a remote |
Producer | Indicates that the span describes the parent of an asynchronous request.
This parent span is expected to end before the corresponding child |
Consumer | Indicates that the span describes the child of an asynchronous |
Internal | Default value. Indicates that the span represents an internal operation within an application, as opposed to an operations with remote parents or children. |
defaultSpanArguments :: SpanArguments Source #
Smart constructor for SpanArguments
providing reasonable values for most Span
s created
that are internal to an application.
Defaults:
kind
:Internal
attributes
:[]
links
:[]
startTime
:Nothing
(getTimestamp
will be called uponSpan
creation)
data SpanArguments Source #
Non-name fields that may be set on initial creation of a Span
.
SpanArguments | |
|
This is a link that is being added to a span which is going to be created.
A Span
may be linked to zero or more other Spans
(defined by SpanContext
) that are causally related.
Link
s can point to Spans inside a single Trace or across different Traces. Link
s can be used to represent
batched operations where a Span
was initiated by multiple initiating Spans, each representing a single incoming
item being processed in the batch.
Another example of using a Link is to declare the relationship between the originating and following trace. This can be used when a Trace enters trusted boundaries of a service and service policy requires the generation of a new Trace rather than trusting the incoming Trace context. The new linked Trace may also represent a long running asynchronous data processing operation that was initiated by one of many fast incoming requests.
When using the scattergather (also called forkjoin) pattern, the root operation starts multiple downstream processing operations and all of them are aggregated back in a single Span. This last Span is linked to many operations it aggregates. All of them are the Spans from the same Trace. And similar to the Parent field of a Span. It is recommended, however, to not set parent of the Span in this scenario as semantically the parent field represents a single parent scenario, in many cases the parent Span fully encloses the child Span. This is not the case in scatter/gather and batch scenarios.
NewLink | |
|
This is an immutable link for an existing span.
A Span
may be linked to zero or more other Spans
(defined by SpanContext
) that are causally related.
Link
s can point to Spans inside a single Trace or across different Traces. Link
s can be used to represent
batched operations where a Span
was initiated by multiple initiating Spans, each representing a single incoming
item being processed in the batch.
Another example of using a Link is to declare the relationship between the originating and following trace. This can be used when a Trace enters trusted boundaries of a service and service policy requires the generation of a new Trace rather than trusting the incoming Trace context. The new linked Trace may also represent a long running asynchronous data processing operation that was initiated by one of many fast incoming requests.
When using the scattergather (also called forkjoin) pattern, the root operation starts multiple downstream processing operations and all of them are aggregated back in a single Span. This last Span is linked to many operations it aggregates. All of them are the Spans from the same Trace. And similar to the Parent field of a Span. It is recommended, however, to not set parent of the Span in this scenario as semantically the parent field represents a single parent scenario, in many cases the parent Span fully encloses the child Span. This is not the case in scatter/gather and batch scenarios.
Link | |
|
Recording Event
s
A “log” that happens as part of a span. An operation that is too fast for its own span, but too unique to roll up into its parent span.
Events contain a name, a timestamp, and an optional set of Attributes, along with a timestamp. Events represent an event that occurred at a specific time within a span’s workload.
Event | |
|
A “log” that happens as part of a span. An operation that is too fast for its own span, but too unique to roll up into its parent span.
Events contain a name, a timestamp, and an optional set of Attributes, along with a timestamp. Events represent an event that occurred at a specific time within a span’s workload.
When creating an event, this is the version that you will use. Attributes added that exceed the configured attribute limits will be dropped,
which is accounted for in the Event
structure.
Since: 0.0.1.0
NewEvent | |
|
addEvent :: MonadIO m => Span -> NewEvent -> m () Source #
Add an event to a recording span. Events will not be recorded for remote spans and dropped spans.
Since: 0.0.1.0
Enriching Span
s with additional information
:: MonadIO m | |
=> Span | |
-> Text | The new span name, which supersedes whatever was passed in when the Span was started |
-> m () |
Updates the Span name. Upon this update, any sampling behavior based on Span name will depend on the implementation.
Note that Sampler
s can only consider information already present during span creation. Any changes done later, including updated span name, cannot change their decisions.
Alternatives for the name update may be late Span creation, when Span is started with the explicit timestamp from the past at the moment where the final Span name is known, or reporting a Span with the desired name as a child Span.
Since: 0.0.1.0
:: (MonadIO m, ToAttribute a) | |
=> Span | Span to add the attribute to |
-> Text | Attribute name |
-> a | Attribute value |
-> m () |
Add an attribute to a span. Only has a useful effect on recording spans.
As an application developer when you need to record an attribute first consult existing semantic conventions for Resources, Spans, and Metrics. If an appropriate name does not exists you will need to come up with a new name. To do that consider a few options:
The name is specific to your company and may be possibly used outside the company as well. To avoid clashes with names introduced by other companies (in a distributed system that uses applications from multiple vendors) it is recommended to prefix the new name by your company’s reverse domain name, e.g. 'com.acme.shopname'.
The name is specific to your application that will be used internally only. If you already have an internal company process that helps you to ensure no name clashes happen then feel free to follow it. Otherwise it is recommended to prefix the attribute name by your application name, provided that the application name is reasonably unique within your organization (e.g. 'myuniquemapapp.longitude' is likely fine). Make sure the application name does not clash with an existing semantic convention namespace.
The name may be generally applicable to applications in the industry. In that case consider submitting a proposal to this specification to add a new name to the semantic conventions, and if necessary also to add a new namespace.
It is recommended to limit names to printable Basic Latin characters (more precisely to 'U+0021' .. 'U+007E' subset of Unicode code points), although the Haskell OpenTelemetry specification DOES provide full Unicode support.
Attribute names that start with 'otel.' are reserved to be defined by OpenTelemetry specification. These are typically used to express OpenTelemetry concepts in formats that don’t have a corresponding concept.
For example, the 'otel.library.name' attribute is used to record the instrumentation library name, which is an OpenTelemetry concept that is natively represented in OTLP, but does not have an equivalent in other telemetry formats and protocols.
Any additions to the 'otel.*' namespace MUST be approved as part of OpenTelemetry specification.
Since: 0.0.1.0
addAttributes :: MonadIO m => Span -> [(Text, Attribute)] -> m () Source #
A convenience function related to addAttribute
that adds multiple attributes to a span at the same time.
This function may be slightly more performant than repeatedly calling addAttribute
.
Since: 0.0.1.0
spanGetAttributes :: MonadIO m => Span -> m Attributes Source #
This can be useful for pulling data for attributes and using it to copy / otherwise use the data to further enrich instrumentation.
An attribute represents user-provided metadata about a span, link, or event.
Telemetry tools may use this data to support high-cardinality querying, visualization in waterfall diagrams, trace sampling decisions, and more.
AttributeValue PrimitiveAttribute | An attribute representing a single primitive value |
AttributeArray [PrimitiveAttribute] | An attribute representing an array of primitive values. All values in the array MUST be of the same primitive attribute type. |
Instances
class ToAttribute a where Source #
Convert a Haskell value to an Attribute
value.
For most values, you can define an instance of ToPrimitiveAttribute
and use the default toAttribute
implementation:
data Foo = Foo instance ToPrimitiveAttribute Foo where toPrimitiveAttribute Foo = TextAttribute Foo instance ToAttribute foo
Nothing
toAttribute :: a -> Attribute Source #
default toAttribute :: ToPrimitiveAttribute a => a -> Attribute Source #
Instances
ToAttribute Bool Source # | |
Defined in OpenTelemetry.Attributes toAttribute :: Bool -> Attribute Source # | |
ToAttribute Double Source # | |
Defined in OpenTelemetry.Attributes toAttribute :: Double -> Attribute Source # | |
ToAttribute Int Source # | |
Defined in OpenTelemetry.Attributes toAttribute :: Int -> Attribute Source # | |
ToAttribute Int64 Source # | |
Defined in OpenTelemetry.Attributes toAttribute :: Int64 -> Attribute Source # | |
ToAttribute Text Source # | |
Defined in OpenTelemetry.Attributes toAttribute :: Text -> Attribute Source # | |
ToAttribute PrimitiveAttribute Source # | |
Defined in OpenTelemetry.Attributes | |
ToAttribute Attribute Source # | |
Defined in OpenTelemetry.Attributes toAttribute :: Attribute -> Attribute Source # | |
ToPrimitiveAttribute a => ToAttribute [a] Source # | |
Defined in OpenTelemetry.Attributes toAttribute :: [a] -> Attribute Source # |
data PrimitiveAttribute Source #
Instances
class ToPrimitiveAttribute a where Source #
Convert a Haskell value to a PrimitiveAttribute
value.
Instances
ToPrimitiveAttribute Bool Source # | |
Defined in OpenTelemetry.Attributes | |
ToPrimitiveAttribute Double Source # | |
Defined in OpenTelemetry.Attributes | |
ToPrimitiveAttribute Int Source # | |
Defined in OpenTelemetry.Attributes | |
ToPrimitiveAttribute Int64 Source # | |
Defined in OpenTelemetry.Attributes | |
ToPrimitiveAttribute Text Source # | |
Defined in OpenTelemetry.Attributes | |
ToPrimitiveAttribute PrimitiveAttribute Source # | |
Defined in OpenTelemetry.Attributes |
Recording error information
recordException :: (MonadIO m, Exception e) => Span -> [(Text, Attribute)] -> Maybe Timestamp -> e -> m () Source #
A specialized variant of addEvent
that records attributes conforming to
the OpenTelemetry specification's
semantic conventions
Since: 0.0.1.0
setStatus :: MonadIO m => Span -> SpanStatus -> m () Source #
Sets the Status of the Span. If used, this will override the default Span
status, which is Unset
.
These values form a total order: Ok > Error > Unset. This means that setting Status with StatusCode=Ok will override any prior or future attempts to set span Status with StatusCode=Error or StatusCode=Unset.
Since: 0.0.1.0
data SpanStatus Source #
The status of a Span
. This may be used to indicate the successful completion of a span.
The default is Unset
These values form a total order: Ok > Error > Unset. This means that setting Status with StatusCode=Ok will override any prior or future attempts to set span Status with StatusCode=Error or StatusCode=Unset.
Unset | The default status. |
Error Text | The operation contains an error. The text field may be empty, or else provide a description of the error. |
Ok | The operation has been validated by an Application developer or Operator to have completed successfully. |
Instances
Eq SpanStatus Source # | |
Defined in OpenTelemetry.Internal.Trace.Types (==) :: SpanStatus -> SpanStatus -> Bool # (/=) :: SpanStatus -> SpanStatus -> Bool # | |
Ord SpanStatus Source # | |
Defined in OpenTelemetry.Internal.Trace.Types compare :: SpanStatus -> SpanStatus -> Ordering # (<) :: SpanStatus -> SpanStatus -> Bool # (<=) :: SpanStatus -> SpanStatus -> Bool # (>) :: SpanStatus -> SpanStatus -> Bool # (>=) :: SpanStatus -> SpanStatus -> Bool # max :: SpanStatus -> SpanStatus -> SpanStatus # min :: SpanStatus -> SpanStatus -> SpanStatus # | |
Show SpanStatus Source # | |
Defined in OpenTelemetry.Internal.Trace.Types showsPrec :: Int -> SpanStatus -> ShowS # show :: SpanStatus -> String # showList :: [SpanStatus] -> ShowS # |
Completing Span
s
:: MonadIO m | |
=> Span | |
-> Maybe Timestamp | Optional |
-> m () |
Signals that the operation described by this span has now (or at the time optionally specified) ended.
This does have any effects on child spans. Those may still be running and can be ended later.
This also does not inactivate the Span in any Context it is active in. It is still possible to use an ended span as parent via a Context it is contained in. Also, putting the Span into a Context will still work after the Span was ended.
Since: 0.0.1.0
Accessing other Span
information
getSpanContext :: MonadIO m => Span -> m SpanContext Source #
When sending tracing information across process boundaries,
the SpanContext
is used to serialize the relevant information.
isRecording :: MonadIO m => Span -> m Bool Source #
Returns whether the the Span
is currently recording. If a span
is dropped, this will always return False. If a span is from an
external process, this will return True, and if the span was
created by this process, the span will return True until endSpan
is called.
isValid :: SpanContext -> Bool Source #
Returns True
if the SpanContext
has a non-zero TraceID
and a non-zero SpanID
spanIsRemote :: MonadIO m => Span -> m Bool Source #
Returns True
if the SpanContext
was propagated from a remote parent,
When extracting a SpanContext through the Propagators API, isRemote MUST return True
,
whereas for the SpanContext of any child spans it MUST return False
.
Utilities
getTimestamp :: MonadIO m => m Timestamp Source #
Sometimes, you may have a more accurate notion of when a traced
operation has ended. In this case you may call getTimestamp
, and then
supply endSpan
with the more accurate timestamp you have acquired.
When using the monadic interface, (such as inSpan
, you may call
endSpan
early to record the information, and the first call to endSpan
will be honored.
Since: 0.0.1.0
unsafeReadSpan :: MonadIO m => Span -> m ImmutableSpan Source #
Really only intended for tests, this function does not conform to semantic versioning .
whenSpanIsRecording :: MonadIO m => Span -> m () -> m () Source #
Utility function to only perform costly attribute annotations for spans that are actually
Limits
data SpanLimits Source #
Instances
Eq SpanLimits Source # | |
Defined in OpenTelemetry.Internal.Trace.Types (==) :: SpanLimits -> SpanLimits -> Bool # (/=) :: SpanLimits -> SpanLimits -> Bool # | |
Show SpanLimits Source # | |
Defined in OpenTelemetry.Internal.Trace.Types showsPrec :: Int -> SpanLimits -> ShowS # show :: SpanLimits -> String # showList :: [SpanLimits] -> ShowS # |
bracketError :: MonadUnliftIO m => m a -> (Maybe SomeException -> a -> m b) -> (a -> m c) -> m c Source #
Like bracket
, but provides the after
function with information about
uncaught exceptions.
Since: 0.1.0.0