2025-11-25 11:51:16 +08:00
|
|
|
package jaeger
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
"encoding/json"
|
2025-12-02 18:36:51 +08:00
|
|
|
"strconv"
|
|
|
|
|
|
2025-11-26 10:38:15 +08:00
|
|
|
"github.com/gogf/gf/contrib/trace/otlphttp/v2"
|
2025-11-25 11:51:16 +08:00
|
|
|
"github.com/gogf/gf/v2/frame/g"
|
|
|
|
|
"github.com/gogf/gf/v2/net/ghttp"
|
2025-11-26 10:38:15 +08:00
|
|
|
"github.com/gogf/gf/v2/net/gtrace"
|
2025-11-25 11:51:16 +08:00
|
|
|
"go.opentelemetry.io/otel/attribute"
|
|
|
|
|
)
|
|
|
|
|
|
2025-11-26 10:38:15 +08:00
|
|
|
var ShutDown func(ctx context.Context)
|
2025-11-25 11:51:16 +08:00
|
|
|
|
|
|
|
|
func init() {
|
2025-11-28 14:01:08 +08:00
|
|
|
jaegerAgent := g.Cfg().MustGet(context.Background(), "jaeger.addr").String()
|
2025-12-02 18:36:51 +08:00
|
|
|
serverName := g.Cfg().MustGet(context.Background(), "server.name").String()
|
|
|
|
|
shutdown, err := otlphttp.Init(serverName, jaegerAgent, "/v1/traces")
|
2025-11-25 11:51:16 +08:00
|
|
|
if err != nil {
|
|
|
|
|
panic(err)
|
|
|
|
|
}
|
2025-11-28 14:01:08 +08:00
|
|
|
ShutDown = shutdown
|
2025-11-25 11:51:16 +08:00
|
|
|
}
|
|
|
|
|
func NewTracer(r *ghttp.Request) {
|
2025-11-26 10:38:15 +08:00
|
|
|
_, span := gtrace.NewSpan(r.Context(), r.GetServeHandler().GetMetaTag("summary"))
|
|
|
|
|
defer span.End()
|
2025-11-25 11:51:16 +08:00
|
|
|
span.SetAttributes(attribute.String("request", getParams(r)))
|
|
|
|
|
r.Middleware.Next()
|
|
|
|
|
span.SetAttributes(attribute.String("response", r.Response.BufferString()))
|
|
|
|
|
}
|
|
|
|
|
func getParams(r *ghttp.Request) string {
|
|
|
|
|
params := map[string]interface{}{}
|
|
|
|
|
if r.Method == "POST" {
|
|
|
|
|
json.Unmarshal(r.GetBody(), ¶ms) //获取raw传参
|
|
|
|
|
}
|
|
|
|
|
if r.Method == "GET" {
|
|
|
|
|
r.Request.ParseForm()
|
|
|
|
|
form := r.Form
|
|
|
|
|
for k, v := range form {
|
|
|
|
|
if vl, e := strconv.Atoi(v[0]); e == nil {
|
|
|
|
|
params[k] = vl
|
|
|
|
|
} else {
|
|
|
|
|
params[k] = v[0]
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
rp, _ := json.Marshal(¶ms)
|
|
|
|
|
return string(rp)
|
|
|
|
|
}
|