package trace
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=97cc4159b96429adc01a84bff1ed34b8f06746bc56a40a214a6306036be2df38
sha512=6a67ea9ddeebb4b93a0b8dba9ed26d95e786722d08fd9ca7d8e2db7651a9b9d6ccc63cc437b4eb71c28b3ec51838716a84707a8d366abb595f32a5e65035e28b
doc/trace.core/Trace_core/index.html
Module Trace_core
Source
Trace.
A span identifier.
The meaning of the identifier depends on the collector.
User defined data, generally passed as key/value pairs to whatever collector is installed (if any).
type explicit_span = {
span : span;
(*Identifier for this span. Several explicit spans might share the same identifier since we can differentiate between them via
*)meta
.mutable meta : Meta_map.t;
(*Metadata for this span (and its context)
*)
}
Explicit span, with collector-specific metadata
Tracing
Is there a collector?
This is fast, so that the traced program can check it before creating any span or message.
val with_span :
?__FUNCTION__:string ->
__FILE__:string ->
__LINE__:int ->
?data:(unit -> (string * user_data) list) ->
string ->
(span -> 'a) ->
'a
with_span ~__FILE__ ~__LINE__ name f
enters a new span sp
, and calls f sp
. sp
might be a dummy span if no collector is installed. When f sp
returns or raises, the span sp
is exited.
This is the recommended way to instrument most code.
NOTE an important restriction is that this is only supposed to work for synchronous, direct style code. Monadic concurrency, Effect-based fibers, etc. might not play well with this style of spans on some or all backends. If you use cooperative concurrency, see enter_manual_span
.
Add structured data to the given active span (see with_span
). Behavior is not specified if the span has been exited.
val enter_manual_sub_span :
parent:explicit_span ->
?flavor:[ `Sync | `Async ] ->
?__FUNCTION__:string ->
__FILE__:string ->
__LINE__:int ->
?data:(unit -> (string * user_data) list) ->
string ->
explicit_span
Like with_span
but the caller is responsible for obtaining the parent
span from their own caller, and carry the resulting explicit_span
to the matching exit_manual_span
.
val enter_manual_toplevel_span :
?flavor:[ `Sync | `Async ] ->
?__FUNCTION__:string ->
__FILE__:string ->
__LINE__:int ->
?data:(unit -> (string * user_data) list) ->
string ->
explicit_span
Like with_span
but the caller is responsible for carrying this explicit_span
around until it's exited with exit_manual_span
. The span can be used as a parent in enter_manual_sub_span
.
Exit an explicit span. This can be on another thread, in a fiber or lightweight thread, etc. and will be supported by backends nonetheless. The span can be obtained via enter_manual_sub_span
or enter_manual_toplevel_span
.
add_data_explicit esp data
adds data
to the span esp
. The behavior is not specified is the span has been exited already.
message msg
logs a message msg
(if a collector is installed). Additional metadata can be provided.
val messagef :
?span:span ->
?data:(unit -> (string * user_data) list) ->
((('a, Format.formatter, unit, unit) format4 -> 'a) -> unit) ->
unit
messagef (fun k->k"hello %s %d!" "world" 42)
is like message "hello world 42!"
but only computes the string formatting if a collector is installed.
Give a name to the current thread. This might be used by the collector to display traces in a more informative way.
Give a name to the current process. This might be used by the collector to display traces in a more informative way.
Emit a counter of type int
. Counters represent the evolution of some quantity over time.
Emit a counter of type float
. See counter_int
for more details.
Collector
An event collector.
See Collector
for more details.
shutdown ()
shutdowns the current collector, if one was installed, and waits for it to terminate before returning.