Documentation
¶
Overview ¶
Package telemetry provides telemetry exporters: am-dbg, Prometheus, OpenTelemetry.
Index ¶
- Constants
- func BindLokiEnv(mach am.Api) error
- func BindLokiLogger(mach am.Api, client promtail.Client)
- func BindOtelLogger(mach am.Api, provider *ologsdk.LoggerProvider, service string)
- func MachBindOtelEnv(mach am.Api) error
- func NewOtelLoggerProvider(exporter ologsdk.Exporter) *ologsdk.LoggerProvider
- func NewOtelProvider(source string, ctx context.Context) (trace.Tracer, *sdktrace.TracerProvider, error)
- func NormalizeId(id string) string
- type OtelMachTracer
- func (mt *OtelMachTracer) End()
- func (mt *OtelMachTracer) HandlerEnd(tx *am.Transition, emitter string, handler string)
- func (mt *OtelMachTracer) MachineDispose(id string)
- func (mt *OtelMachTracer) MachineInit(mach am.Api) context.Context
- func (mt *OtelMachTracer) NewSubmachine(parent, mach am.Api)
- func (mt *OtelMachTracer) QueueEnd(mach am.Api)
- func (mt *OtelMachTracer) TransitionEnd(tx *am.Transition)
- func (mt *OtelMachTracer) TransitionInit(tx *am.Transition)
- type OtelMachTracerOpts
- type OtelMachineData
- type OtelTxHist
Constants ¶
const ( EnvService = "AM_SERVICE" EnvLokiAddr = "AM_LOKI_ADDR" EnvOtelTrace = "AM_OTEL_TRACE" EnvOtelTraceTxs = "AM_OTEL_TRACE_TXS" EnvOtelTraceArgs = "AM_OTEL_TRACE_ARGS" EnvOtelTraceNoauto = "AM_OTEL_TRACE_NOAUTO" )
Variables ¶
This section is empty.
Functions ¶
func BindLokiEnv ¶ added in v0.11.0
BindLokiEnv bind Loki logger to [mach], based on environment vars: - AM_SERVICE (required) - AM_LOKI_ADDR (required) This tracer is NOT inherited by submachines.
func BindOtelLogger ¶ added in v0.8.0
func BindOtelLogger( mach am.Api, provider *ologsdk.LoggerProvider, service string, )
BindOtelLogger binds an OpenTelemetry logger to a machine.
func MachBindOtelEnv ¶ added in v0.10.3
MachBindOtelEnv bind an OpenTelemetry tracer to [mach], based on environment variables: - AM_SERVICE (required) - AM_OTEL_TRACE (required) - AM_OTEL_TRACE_TXS - OTEL_EXPORTER_OTLP_ENDPOINT - OTEL_EXPORTER_OTLP_TRACES_ENDPOINT
This tracer is inherited by submachines, and this function applies only to top-level machines.
func NewOtelLoggerProvider ¶ added in v0.8.0
func NewOtelLoggerProvider(exporter ologsdk.Exporter) *ologsdk.LoggerProvider
NewOtelLoggerProvider creates a new OpenTelemetry logger provider bound to the given exporter.
func NewOtelProvider ¶ added in v0.10.3
func NormalizeId ¶ added in v0.8.0
Types ¶
type OtelMachTracer ¶ added in v0.5.0
type OtelMachTracer struct {
*am.TracerNoOp
Tracer trace.Tracer
Machines map[string]*OtelMachineData
MachinesMx sync.Mutex
MachinesOrder []string
RootSpan trace.Span
// TODO bind to env var
Logf func(format string, args ...any)
NextIndex int
// contains filtered or unexported fields
}
OtelMachTracer implements machine.Tracer for OpenTelemetry. Supports tracing of multiple state machines, resulting in a single trace. This tracer is automatically bound to new sub-machines.
func NewOtelMachTracer ¶ added in v0.5.0
func NewOtelMachTracer( rootMach am.Api, rootSpan trace.Span, otelTracer trace.Tracer, opts *OtelMachTracerOpts, ) *OtelMachTracer
NewOtelMachTracer creates a new machine tracer from an OpenTelemetry tracer. Requires OtelMachTracer.Dispose to be called at the end.
func (*OtelMachTracer) End ¶ added in v0.5.0
func (mt *OtelMachTracer) End()
func (*OtelMachTracer) HandlerEnd ¶ added in v0.5.0
func (mt *OtelMachTracer) HandlerEnd( tx *am.Transition, emitter string, handler string, )
func (*OtelMachTracer) MachineDispose ¶ added in v0.5.0
func (mt *OtelMachTracer) MachineDispose(id string)
func (*OtelMachTracer) MachineInit ¶ added in v0.5.0
func (mt *OtelMachTracer) MachineInit(mach am.Api) context.Context
func (*OtelMachTracer) NewSubmachine ¶ added in v0.5.0
func (mt *OtelMachTracer) NewSubmachine(parent, mach am.Api)
NewSubmachine links 2 machines with a parent-child relationship.
func (*OtelMachTracer) QueueEnd ¶ added in v0.6.0
func (mt *OtelMachTracer) QueueEnd(mach am.Api)
func (*OtelMachTracer) TransitionEnd ¶ added in v0.5.0
func (mt *OtelMachTracer) TransitionEnd(tx *am.Transition)
func (*OtelMachTracer) TransitionInit ¶ added in v0.5.0
func (mt *OtelMachTracer) TransitionInit(tx *am.Transition)
type OtelMachTracerOpts ¶ added in v0.5.0
type OtelMachTracerOpts struct {
// if true, only state changes will be traced
SkipTransitions bool
// if true, only Healthcheck and Heartbeat will be skipped
IncludeHealth bool
// if true, transition traces won't include [am.Machine.GetLogArgs]
SkipLogArgs bool
// if true, auto transitions won't be traced
SkipAuto bool
// TODO
AllowStates am.S
// TODO
SkipStates am.S
Logf func(format string, args ...any)
}
type OtelMachineData ¶ added in v0.5.0
type OtelTxHist ¶ added in v0.11.0
Directories
¶
| Path | Synopsis |
|---|---|
|
Package prometheus provides Prometheus metrics for asyncmachine.
|
Package prometheus provides Prometheus metrics for asyncmachine. |