gozero框架异步任务logx trace id

import (

"go.opentelemetry.io/otel/trace"

// "github.com/zeromicro/go-zero/core/limit"

"github.com/zeromicro/go-zero/core/logx"

...

)

func New Logic(ctx context.Context, svcCtx *svc.ServiceContext) *StockOrderLogic {

// 为每条消息生成独立的 trace ID

// UUID 格式: "550e8400-e29b-41d4-a716-446655440000"

// OpenTelemetry TraceID 需要 32 个十六进制字符(去掉连字符)

// OpenTelemetry SpanID 需要 16 个十六进制字符

traceUUID := uuid.New()

spanUUID := uuid.New()

// 将 UUID 转换为十六进制字符串(去掉连字符)

traceIDHex := strings.ReplaceAll(traceUUID.String(), "-", "")

spanIDHex := strings.ReplaceAll(spanUUID.String(), "-", "")

// SpanID 只需要前 16 个字符

if len(spanIDHex) > 16 {

spanIDHex = spanIDHex[:16]

} else if len(spanIDHex) < 16 {

// 如果不足 16 个字符,用 0 补齐

spanIDHex = spanIDHex + strings.Repeat("0", 16-len(spanIDHex))

}

// 创建 OpenTelemetry trace ID 和 span ID

traceIDBytes, err := trace.TraceIDFromHex(traceIDHex)

if err != nil {

// 如果解析失败,使用空值(但这种情况不应该发生)

traceIDBytes = trace.TraceID{}

}

spanIDBytes, err := trace.SpanIDFromHex(spanIDHex)

if err != nil {

// 如果解析失败,使用空值

spanIDBytes = trace.SpanID{}

}

// 创建 span context

spanCtx := trace.NewSpanContext(trace.SpanContextConfig{

TraceID: traceIDBytes,

SpanID: spanIDBytes,

Remote: false,

})

// 将 span context 注入到 context 中

ctx = trace.ContextWithSpanContext(ctx, spanCtx)

// 同时设置自定义 key(备用,确保兼容性)

ctx = context.WithValue(ctx, traceIDKey, traceIDHex)

ctx = context.WithValue(ctx, spanIDKey, spanIDHex)

return &BussLogic{

Logger: logx.WithContext(ctx),

ctx: ctx,

svcCtx: svcCtx,

}

}

相关推荐
姚不倒11 小时前
从零实现一个基于 Ollama + Go + MySQL 的 Text-to-SQL 智能体(M1 实战)
sql·mysql·云原生·golang
wlsh1519 小时前
Go 泛型笔记
golang
姚不倒19 小时前
从「LeetCode LRU 缓存」到「生产级 Go Web 服务」:我如何迈出工程化第一步
leetcode·缓存·云原生·golang
止语Lab20 小时前
从 sync.Map 到 Redis:Go 缓存升级的三个拐点
redis·缓存·golang
XMYX-020 小时前
40 - Go HTTP 客户端:从 http.Get 到高性能连接池
开发语言·http·golang
XMYX-021 小时前
39 - Go 信号捕获与处理:优雅退出、进程控制
开发语言·golang
mumu_wangwei2 天前
【QFS】Golang自研的QFS分布式文件系统,QFS文件系统使用
开发语言·后端·golang
codeejun2 天前
每日一Go-66、K8s 蓝绿发布 & 金丝雀发布实战:Service 切流量 + Ingress 灰度一次讲透
开发语言·golang·kubernetes
青春喂了后端2 天前
Go Sidecar Repository 并发锁改造:让并发请求安全地进入 Git 仓库层
git·安全·golang
2501_931803752 天前
Go 接口学习笔记:从语法到心法
笔记·学习·golang