-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathtracer.go
88 lines (70 loc) · 2.26 KB
/
tracer.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
package tracer
import (
"context"
"github.com/alexfalkowski/go-service/env"
se "github.com/alexfalkowski/go-service/errors"
"go.opentelemetry.io/otel"
"go.opentelemetry.io/otel/exporters/otlp/otlptrace"
otlp "go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp"
"go.opentelemetry.io/otel/propagation"
"go.opentelemetry.io/otel/sdk/resource"
sdktrace "go.opentelemetry.io/otel/sdk/trace"
semconv "go.opentelemetry.io/otel/semconv/v1.26.0"
"go.opentelemetry.io/otel/trace"
"go.opentelemetry.io/otel/trace/noop"
"go.uber.org/fx"
"go.uber.org/zap"
)
// OperationName for tracer.
func OperationName(area, name string) string {
return area + ": " + name
}
// Register for tracer.
func Register() {
otel.SetTextMapPropagator(propagation.TraceContext{})
}
// NewTracer for tracer.
func NewTracer(lc fx.Lifecycle, env env.Environment, ver env.Version, name env.Name, cfg *Config, logger *zap.Logger) (trace.Tracer, error) {
if !IsEnabled(cfg) {
return noop.Tracer{}, nil
}
opts := []otlp.Option{otlp.WithEndpointURL(cfg.Host)}
if cfg.HasKey() {
k, err := cfg.GetKey()
if err != nil {
return nil, err
}
opts = append(opts, otlp.WithHeaders(map[string]string{"Authorization": "Basic " + k}))
}
return newTracer(lc, env, ver, name, logger, opts), nil
}
func newTracer(lc fx.Lifecycle, env env.Environment, ver env.Version, name env.Name, logger *zap.Logger, opts []otlp.Option) trace.Tracer {
client := otlp.NewClient(opts...)
exporter := otlptrace.NewUnstarted(client)
attrs := resource.NewWithAttributes(
semconv.SchemaURL,
semconv.ServiceName(string(name)),
semconv.ServiceVersion(string(ver)),
semconv.DeploymentEnvironment(string(env)),
)
p := sdktrace.NewTracerProvider(sdktrace.WithResource(attrs), sdktrace.WithBatcher(exporter))
otel.SetTracerProvider(p)
otel.SetErrorHandler(&errorHandler{logger: logger})
lc.Append(fx.Hook{
OnStart: func(ctx context.Context) error {
return se.Prefix("start tracer", exporter.Start(ctx))
},
OnStop: func(ctx context.Context) error {
_ = p.Shutdown(ctx)
_ = exporter.Shutdown(ctx)
return nil
},
})
return p.Tracer(string(name))
}
type errorHandler struct {
logger *zap.Logger
}
func (e *errorHandler) Handle(err error) {
e.logger.Error("trace: global error", zap.Error(err))
}