当使用otel(OpenTelemetry)包实现链路追踪的 Demo时,你需要先安装相关依赖。以下是一个简单的示例代码,用于演示如何在 Golang 中使用 otel 包进行链路追踪:
package main
import (
"context"
"fmt"
"log"
"net/http"
"time"
sdktrace "go.opentelemetry.io/otel/sdk/trace"
"go.opentelemetry.io/otel/trace"
"go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp"
)
func main() {
tp := sdktrace.NewTracerProvider()
defer tp.Shutdown(context.Background())
trace.SetTracerProvider(tp)
mux := http.NewServeMux()
mux.HandleFunc("/", helloHandler)
fmt.Println("Server listening on port 8080...")
if err := http.ListenAndServe(":8080", otelhttp.NewHandler(mux, "server")); err != nil {
log.Fatal(err)
}
}
func helloHandler(w http.ResponseWriter, r *http.Request) {
tracer := trace.Tracer("hello")
ctx, span := tracer.Start(r.Context(), "hello-handler")
defer span.End()
time.Sleep(100 * time.Millisecond)
w.WriteHeader(http.StatusOK)
w.Write([]byte("Hello, World!"))
}
以上代码展示了一个简单的 HTTP 服务器,它使用 otel 包进行链路追踪。首先,在 main() 函数中初始化 TracerProvider 并设置为全局的 Tracer Provider。然后创建一个新的 ServeMux,并将其绑定到 / 路径上的 helloHandler 函数。
在 helloHandler 函数中,我们使用 trace.Tracer("hello") 创建了一个名为 “hello” 的 Tracer。然后,在处理函数的开头和结尾,我们使用 Start() 和 End() 函数创建和结束一个 Span。
运行该示例代码后,访问 http://localhost:8080/ 可以看到 “Hello, World!” 的响应。同时,链路追踪数据将通过默认的 OTLP 导出器发送给后端,你可以根据需要配置其他导出器来存储和分析链路追踪数据。
这只是一个简单的示例,你可以根据自己的需求进行扩展和修改。希望对你有所帮助!
内容由零声教学AI助手提供,问题来源于学员提问




