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,

}

}

相关推荐
Tony Bai9 小时前
“Go 2,请不要发生!”:如果 Go 变成了“缝合怪”,你还会爱它吗?
开发语言·后端·golang
灰子学技术18 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
源代码•宸1 天前
大厂技术岗面试之谈薪资
经验分享·后端·面试·职场和发展·golang·大厂·职级水平的薪资
有代理ip2 天前
Python 与 Golang 爬虫的隐藏优势
爬虫·python·golang
天远云服2 天前
天远车辆过户查询API微服务实战:用Go语言构建高性能车况溯源系统
大数据·微服务·架构·golang
女王大人万岁2 天前
Go标准库 sync 详解
服务器·开发语言·后端·golang
小高Baby@2 天前
session、cookie、Jwt-token
开发语言·后端·golang
Grassto2 天前
12 go.sum 是如何保证依赖安全的?校验机制源码解析
安全·golang·go·哈希算法·go module
小二·2 天前
Go 语言系统编程与云原生开发实战(第12篇)云原生部署实战:Helm Chart × GitOps × 多环境管理(生产级落地)
开发语言·云原生·golang
天空属于哈夫克32 天前
Go 语言实战:构建一个企微外部群“技术贴收藏夹”小程序后端
小程序·golang·企业微信