Packages

trait Tracer[F[_]] extends AnyRef

Tracer acts as an abstraction layer over tracing.

General idea is to create span around fa: F[A], evaluate the results of F[A] and report span to underlying tracing solution.

Usage:

tracer.trace("fetch_user", "user_id" -> Tag.int(42)) {
  readFromDB(userId=42)
} //the moment `readFromDB` is evaluated, span "fetch_user" is finished
Linear Supertypes
AnyRef, Any
Known Subclasses
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Tracer
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Abstract Value Members

  1. abstract def trace[A](operationName: String, parent: Option[Context], tags: (String, Tag)*)(fa: F[A]): F[A]

    Same as basic trace but with explicit optional parent's context.

    Same as basic trace but with explicit optional parent's context. Usually used on the edge of tracing initialization in combination with TraceCarrier

    operationName

    name of span

    parent

    parent context to use

    tags

    tags to add to span

    fa

    operation to trace

  2. abstract def trace[A](operationName: String, parent: Span, tags: (String, Tag)*)(fa: F[A]): F[A]

    Same as basic trace but with explicit parent set

    Same as basic trace but with explicit parent set

    operationName

    name of span

    parent

    parent span to use

    tags

    tags to add to span

    fa

    operation to trace

  3. abstract def trace[A](operationName: String, tags: (String, Tag)*)(fa: F[A]): F[A]

    Traces evaluation of fa.

    Traces evaluation of fa. Implementation might use parent span extracted from context of F[_] if it exists.

    Example of effect that could carry span information: io.monix.Task with TaskLocal, Kleisli, StateT

    operationName

    name of span

    tags

    tags to add to span

    fa

    operation to trace

  4. abstract def traceWith[A](operationName: String, parent: Option[Context], tags: (String, Tag)*)(fa: (Span) => F[(Span, A)]): F[A]

    Same as basic traceWith but with explicit optional parent's context.

    Same as basic traceWith but with explicit optional parent's context. Usually used on the edge of tracing initialization in combination with TraceCarrier

    operationName

    name of span

    parent

    parent context to use

    tags

    tags to add to span

    fa

    function that accepts span and returns potentially modified one together with evaluation results

  5. abstract def traceWith[A](operationName: String, parent: Span, tags: (String, Tag)*)(fa: (Span) => F[(Span, A)]): F[A]

    Same as basic traceWith but with explicit parent set

    Same as basic traceWith but with explicit parent set

    operationName

    name of span

    parent

    parent context to use

    tags

    tags to add to span

    fa

    function that accepts span and returns potentially modified one together with evaluation results

  6. abstract def traceWith[A](operationName: String, tags: (String, Tag)*)(fa: (Span) => F[(Span, A)]): F[A]

    Traces evaluation of fa.

    Traces evaluation of fa. Implementation might use parent span extracted from context of F[_] if it exists. It's possible to operate on the span after it was created but before it's committed, i.e. add tags & logs

    operationName

    name of span

    tags

    tags to add to span

    fa

    function that accepts span and returns potentially modified one together with evaluation results

Concrete Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##: Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  5. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native()
  6. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  7. def equals(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef → Any
  8. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable])
  9. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  10. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  11. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  12. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  13. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  14. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  15. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  16. def toString(): String
    Definition Classes
    AnyRef → Any
  17. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  18. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  19. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()

Inherited from AnyRef

Inherited from Any

Ungrouped