traefik/tracing/jaeger/jaeger.go

79 lines
2.5 KiB
Go
Raw Normal View History

2018-01-10 17:48:04 +01:00
package jaeger
import (
2018-08-01 12:52:03 +01:00
"fmt"
2018-01-10 17:48:04 +01:00
"io"
"github.com/containous/traefik/log"
"github.com/opentracing/opentracing-go"
jaeger "github.com/uber/jaeger-client-go"
2018-01-10 17:48:04 +01:00
jaegercfg "github.com/uber/jaeger-client-go/config"
2018-08-01 12:52:03 +01:00
"github.com/uber/jaeger-client-go/zipkin"
2018-01-10 17:48:04 +01:00
jaegermet "github.com/uber/jaeger-lib/metrics"
)
// Name sets the name of this tracer
const Name = "jaeger"
// Config provides configuration settings for a jaeger tracer
type Config struct {
SamplingServerURL string `description:"set the sampling server url." export:"false"`
SamplingType string `description:"set the sampling type." export:"true"`
SamplingParam float64 `description:"set the sampling parameter." export:"true"`
LocalAgentHostPort string `description:"set jaeger-agent's host:port that the reporter will used." export:"false"`
Gen128Bit bool `description:"generate 128 bit span IDs." export:"true"`
Propagation string `description:"which propgation format to use (jaeger/b3)." export:"true"`
TraceContextHeaderName string `description:"set the header to use for the trace-id." export:"true"`
2018-01-10 17:48:04 +01:00
}
// Setup sets up the tracer
func (c *Config) Setup(componentName string) (opentracing.Tracer, io.Closer, error) {
jcfg := jaegercfg.Configuration{
Sampler: &jaegercfg.SamplerConfig{
SamplingServerURL: c.SamplingServerURL,
Type: c.SamplingType,
Param: c.SamplingParam,
},
Reporter: &jaegercfg.ReporterConfig{
LogSpans: true,
LocalAgentHostPort: c.LocalAgentHostPort,
2018-01-10 17:48:04 +01:00
},
Headers: &jaeger.HeadersConfig{
TraceContextHeaderName: c.TraceContextHeaderName,
},
2018-01-10 17:48:04 +01:00
}
jMetricsFactory := jaegermet.NullFactory
2018-08-01 12:52:03 +01:00
opts := []jaegercfg.Option{
2018-11-14 10:18:03 +01:00
jaegercfg.Logger(newJaegerLogger()),
2018-08-01 12:52:03 +01:00
jaegercfg.Metrics(jMetricsFactory),
jaegercfg.Gen128Bit(c.Gen128Bit),
}
switch c.Propagation {
case "b3":
p := zipkin.NewZipkinB3HTTPHeaderPropagator()
opts = append(opts,
jaegercfg.Injector(opentracing.HTTPHeaders, p),
jaegercfg.Extractor(opentracing.HTTPHeaders, p),
)
case "jaeger", "":
default:
return nil, nil, fmt.Errorf("unknown propagation format: %s", c.Propagation)
}
2018-01-10 17:48:04 +01:00
// Initialize tracer with a logger and a metrics factory
closer, err := jcfg.InitGlobalTracer(
componentName,
2018-08-01 12:52:03 +01:00
opts...,
2018-01-10 17:48:04 +01:00
)
if err != nil {
2018-11-14 10:18:03 +01:00
log.WithoutContext().Warnf("Could not initialize jaeger tracer: %s", err.Error())
2018-01-10 17:48:04 +01:00
return nil, nil, err
}
2018-11-14 10:18:03 +01:00
log.WithoutContext().Debug("Jaeger tracer configured")
2018-01-10 17:48:04 +01:00
return opentracing.GlobalTracer(), closer, nil
}