Files
common/jaeger/jaeger.go

63 lines
1.6 KiB
Go
Raw Normal View History

2025-11-25 11:51:16 +08:00
package jaeger
import (
"context"
"encoding/json"
2025-12-02 18:36:51 +08:00
"strconv"
2025-12-03 16:39:55 +08:00
"strings"
2025-12-02 18:36:51 +08:00
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()
2025-12-03 16:39:55 +08:00
// 清理响应字符串,确保 UTF-8 有效(处理二进制数据如 ZIP 文件)
response := r.Response.BufferString()
cleanResponse := strings.ToValidUTF8(response, "")
// 如果响应太大(如文件下载),只记录前 1000 字符
if len(cleanResponse) > 1000 {
cleanResponse = cleanResponse[:1000] + "... (truncated)"
}
span.SetAttributes(attribute.String("response", cleanResponse))
2025-11-25 11:51:16 +08:00
}
func getParams(r *ghttp.Request) string {
params := map[string]interface{}{}
if r.Method == "POST" {
json.Unmarshal(r.GetBody(), &params) //获取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(&params)
return string(rp)
}