All notable changes to this project will be documented in this file. See Conventional Commits for commit guidelines.
2.4.1 (2018-12-11)
- Resolve unknown dialyzer type error
-
don't silence errors on span update calls (#90)
-
update span on finish trace/update (#88)
2.4.0 (2018-10-11)
- Add(bring back) span and trace decorators
Spandex.current_context/1
andSpandex.Tracer.current_context/1
functions, which get aSpandex.SpanContext
struct based on the current context.Spandex.inject_context/3
andSpandex.Tracer.inject_context/2
functions, which inject a distributed tracing context into a list of HTTP headers.
- The
Spandex.Adapter
behaviour now requires aninject_context/3
callback, which encodes aSpandex.SpanContext
as HTTP headers for distributed tracing.
- The
Spandex.Trace
struct now includespriority
andbaggage
fields, to support priority sampling of distributed traces and trace-level baggage, respectively. More details about these concepts can be found in the OpenTracing documentation. An updated version of thespandex_datadog
library will enable support for this feature in terms of theSpandex.Adapter
andSender
APIs.
- It is no longer required that you specify the
env
option. If not specified, it will default tonil
. This is useful, for example, for allowing the Datadog trace collector configured default to be used. - The
Spandex.Adapter.distributed_context/2
callback now expects aSpanContext
struct to be returned, rather than aMap
. - Similarly, the
Spandex.continue_trace
function now expects aSpanContext
struct rather than a separatetrace_id
andspan_id
. - The sender API now calls the
send_trace
function, passing in aSpandex.Trace
struct, rather than passing a list ofSpandex.Span
structs. This means that you need to update thespandex_datadog
to a compatible version.
Spandex.continue_trace/4
is deprecated in favor ofSpandex.continue_trace/3
- Similarly,
Tracer.continue_trace/4
is deprecated in favor ofTracer.continue_trace/3
It is recommended to reread the README, to see the upgrade guide and understand the changes.
- Massive changes, including separating adapters into their own repositories
- Many interface changes, specifically around return values
- Adapters now exist in their own repositories
1.6.1 - 2018-06-04
private
key, when updating spans, for non-inheriting meta
1.6.0 - 2018-06-04
- Storage strategy behaviour
- Centralize most storage logic, requiring only the most adapter specific behaviour to be defined by the adapter.
1.5.0 - 2018-06-02
- Interface for updating span metadata, and creating with metadata has been updated
- Check documentation for examples
1.4.1 - 2018-05-31
- Resolved an issue with distributed trace header parsing
1.4.0 - 2018-05-29
- The tracer pattern
- Modernized configuration
- More: Please read the readme again!
1.3.4 - 2018-05-25
- Support distributed tracing via trace headers.
- Added a changelog
- No new changes