pub struct XrayIdGenerator { /* private fields */ }
Expand description

Generates AWS X-Ray compliant Trace and Span ids.

Generates OpenTelemetry formatted TraceId’s and SpanId’s. The TraceId’s are generated so they can be backed out into X-Ray format by the AWS X-Ray Exporter in the OpenTelemetry Collector.

Trace ID Format

A trace_id consists of three numbers separated by hyphens. For example, 1-58406520-a006649127e371903a2de979. This includes:

  • The version number, that is, 1.
  • The time of the original request, in Unix epoch time, in 8 hexadecimal digits.
  • For example, 10:00AM December 1st, 2016 PST in epoch time is 1480615200 seconds, or 58406520 in hexadecimal digits.
  • A 96-bit identifier for the trace, globally unique, in 24 hexadecimal digits.

See the AWS X-Ray Documentation for more details.

Example

use opentelemetry::trace::noop::NoopSpanExporter;
use opentelemetry::sdk::trace::{self, TracerProvider, XrayIdGenerator};

let _provider: TracerProvider = TracerProvider::builder()
    .with_simple_exporter(NoopSpanExporter::new())
    .with_config(trace::config().with_id_generator(XrayIdGenerator::default()))
    .build();

Trait Implementations§

source§

impl Debug for XrayIdGenerator

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for XrayIdGenerator

source§

fn default() -> XrayIdGenerator

Returns the “default value” for a type. Read more
source§

impl IdGenerator for XrayIdGenerator

source§

fn new_trace_id(&self) -> TraceId

Generates a new TraceId that can be converted to an X-Ray Trace ID

source§

fn new_span_id(&self) -> SpanId

Generates a new SpanId that can be converted to an X-Ray Segment ID

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FutureExt for T

source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

source§

fn vzip(self) -> V