2018-07-13 18:40:28 +03:00
|
|
|
package tracing
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io"
|
|
|
|
"os"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/log"
|
|
|
|
jaeger "github.com/uber/jaeger-client-go"
|
|
|
|
jaegercfg "github.com/uber/jaeger-client-go/config"
|
|
|
|
cli "gopkg.in/urfave/cli.v1"
|
|
|
|
)
|
|
|
|
|
|
|
|
var Enabled bool = false
|
|
|
|
|
|
|
|
// TracingEnabledFlag is the CLI flag name to use to enable trace collections.
|
|
|
|
const TracingEnabledFlag = "tracing"
|
|
|
|
|
|
|
|
var (
|
|
|
|
Closer io.Closer
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
TracingFlag = cli.BoolFlag{
|
|
|
|
Name: TracingEnabledFlag,
|
|
|
|
Usage: "Enable tracing",
|
|
|
|
}
|
|
|
|
TracingEndpointFlag = cli.StringFlag{
|
|
|
|
Name: "tracing.endpoint",
|
|
|
|
Usage: "Tracing endpoint",
|
|
|
|
Value: "0.0.0.0:6831",
|
|
|
|
}
|
|
|
|
TracingSvcFlag = cli.StringFlag{
|
|
|
|
Name: "tracing.svc",
|
|
|
|
Usage: "Tracing service name",
|
|
|
|
Value: "swarm",
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
// Flags holds all command-line flags required for tracing collection.
|
|
|
|
var Flags = []cli.Flag{
|
|
|
|
TracingFlag,
|
|
|
|
TracingEndpointFlag,
|
|
|
|
TracingSvcFlag,
|
|
|
|
}
|
|
|
|
|
|
|
|
// Init enables or disables the open tracing system.
|
|
|
|
func init() {
|
|
|
|
for _, arg := range os.Args {
|
|
|
|
if flag := strings.TrimLeft(arg, "-"); flag == TracingEnabledFlag {
|
|
|
|
Enabled = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Setup(ctx *cli.Context) {
|
|
|
|
if Enabled {
|
|
|
|
log.Info("Enabling opentracing")
|
|
|
|
var (
|
|
|
|
endpoint = ctx.GlobalString(TracingEndpointFlag.Name)
|
|
|
|
svc = ctx.GlobalString(TracingSvcFlag.Name)
|
|
|
|
)
|
|
|
|
|
|
|
|
Closer = initTracer(endpoint, svc)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func initTracer(endpoint, svc string) (closer io.Closer) {
|
|
|
|
// Sample configuration for testing. Use constant sampling to sample every trace
|
|
|
|
// and enable LogSpan to log every span via configured Logger.
|
|
|
|
cfg := jaegercfg.Configuration{
|
|
|
|
Sampler: &jaegercfg.SamplerConfig{
|
|
|
|
Type: jaeger.SamplerTypeConst,
|
|
|
|
Param: 1,
|
|
|
|
},
|
|
|
|
Reporter: &jaegercfg.ReporterConfig{
|
|
|
|
LogSpans: true,
|
|
|
|
BufferFlushInterval: 1 * time.Second,
|
|
|
|
LocalAgentHostPort: endpoint,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
// Example logger and metrics factory. Use github.com/uber/jaeger-client-go/log
|
|
|
|
// and github.com/uber/jaeger-lib/metrics respectively to bind to real logging and metrics
|
|
|
|
// frameworks.
|
2018-10-17 15:46:59 +03:00
|
|
|
//jLogger := jaegerlog.StdLogger
|
2018-07-13 18:40:28 +03:00
|
|
|
//jMetricsFactory := metrics.NullFactory
|
|
|
|
|
|
|
|
// Initialize tracer with a logger and a metrics factory
|
|
|
|
closer, err := cfg.InitGlobalTracer(
|
|
|
|
svc,
|
2018-10-17 15:46:59 +03:00
|
|
|
//jaegercfg.Logger(jLogger),
|
2018-07-13 18:40:28 +03:00
|
|
|
//jaegercfg.Metrics(jMetricsFactory),
|
|
|
|
//jaegercfg.Observer(rpcmetrics.NewObserver(jMetricsFactory, rpcmetrics.DefaultNameNormalizer)),
|
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
log.Error("Could not initialize Jaeger tracer", "err", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return closer
|
|
|
|
}
|