package main
import (
"log"
"os"
"go.uber.org/zap"
"github.com/jaegertracing/jaeger-client-go"
"github.com/jaegertracing/jaeger-client-go/config"
)
func main() {
// 配置Logger,用于记录Span的信息
logger, _ := zap.NewProduction()
defer logger.Sync()
// 创建Jaeger客户端的配置
cfg := &config.Configuration{
ServiceName: "YourServiceName", // 替换为你的服务名
Sampler: &config.SamplerConfig{
Type: "const",
Param: 1, // 1 表示全部追踪,0 表示不追踪
},
Reporter: &config.ReporterConfig{
LogSpans: true, // 将Span记录到Logger
BufferFlushInterval: 1, // 缓冲区刷新间隔,这里为1秒
},
Logger: logger, // 使用上面配置的Logger
}
// 从环境变量中读取Jaeger代理地址
if err := cfg.FromEnv(); err != nil {
log.Fatalf("解析配置错误: %v\n", err)
}
// 创建Jaeger Tracer
tracer, closer, err := cfg.NewTracer(config.Logger(jaeger.StdLogger))
if err != nil {
log.Fatalf("创建Tracer错误: %v\n", err)
}
defer closer.Close()
// 创建一个新的Span,表示一个服务的开始
span := tracer.StartSpan("some-operation")
// 对Span进行一些操作,例如设置标签等
span.SetTag("some-tag", "some-value")
// 结束Span,表示服务的结束
span.Finish()
}
这段代码展示了如何使用Jaeger客户端Go库创建一个新的追踪Span,并对其进行配置和操作。它还展示了如何从环境变量中读取Jaeger代理地址,并设置追踪的服务名。最后,它创建了一个新的Span,并在其上设置了一个标签,然后正确地结束了该Span。这是使用Jaeger客户端库的一个基本例子,对开发者理解如何在Go语言中使用分布式追踪系统Jaeger非常有帮助。