从使用 golang otelmux 检测的 OTEL 跟踪获取trace_id

2024年 2月 11日 81.8k 0

从使用 golang otelmux 检测的 otel 跟踪获取trace_id

php小编鱼仔将为您介绍使用golang otelmux检测的OTEL跟踪获取trace_id的方法。OTEL(OpenTelemetry)是一个开源的观测性工具,可以帮助开发人员监测和调试分布式应用程序。通过使用golang otelmux,我们可以轻松地在应用程序中集成OTEL跟踪功能,并获取trace_id,以便更好地分析和优化应用程序的性能。接下来,我们将详细介绍如何使用golang otelmux进行OTEL跟踪,并获取trace_id的方法。

问题内容

在我的 golang 应用程序中,我使用 otelmux 中间件和 ddotel 跟踪器提供程序来检测 OTEL 跟踪中间件:

package tracing

import (
"github.com/gorilla/mux"
"go.opentelemetry.io/contrib/instrumentation/github.com/gorilla/mux/otelmux"
ddotel "gopkg.in/DataDog/dd-trace-go.v1/ddtrace/opentelemetry"
"gopkg.in/DataDog/dd-trace-go.v1/ddtrace/tracer"
)

// Middleware returns a tracing middleware that will add a span for each request.
func Middleware(t *TraceProvider) mux.MiddlewareFunc {
sampler := tracer.NewRateSampler(0.1)
provider := ddotel.NewTracerProvider(
tracer.WithSampler(sampler),
tracer.WithRuntimeMetrics(),
)
return otelmux.Middleware("my-service", otelmux.WithTracerProvider(provider))
}

登录后复制

每当跟踪附加到请求时(考虑采样率),我想从根跨度中提取跟踪 ID,这样我就可以将其注入到日志记录 API 中,以便关联来自该请求的日志具有来自同一请求的跟踪。

到目前为止,我还没有找到直接从请求上下文获取跟踪 ID 的方法。

如何提取跟踪 ID?

解决方法

感谢 @hamed-n 评论的最佳解决方案:

trace包中有一个从span上下文中提取trace ID的函数:“go.opentelemetry.io/otel/trace”:

func GetTraceID(ctx context.Context) string {
spanCtx := trace.SpanContextFromContext(ctx)
if spanCtx.HasTraceID() {
traceID := spanCtx.TraceID()
return traceID.String()
}
return ""
}

登录后复制

就我而言,由于我使用的提供程序是 DataDog,因此我必须将跟踪 ID 转换为 uint64 big endian:

func GetTraceID(ctx context.Context) string {
spanCtx := trace.SpanContextFromContext(ctx)
if spanCtx.HasTraceID() {
// Since datadog trace provider (ddtrace) uses big endian uint64 for the trace ID, we must first to first convert it back to uint64.
traceID := spanCtx.TraceID()
traceIDRaw := [16]byte(traceID)
traceIDUint64 := byteArrToUint64(traceIDRaw[8:])
traceIDStr := strconv.FormatUint(traceIDUint64, 10)
return traceIDStr
}
return ""
}

func byteArrToUint64(buf []byte) uint64 {
var x uint64
for i, b := range buf {
x = x登录后复制

以上就是从使用 golang otelmux 检测的 OTEL 跟踪获取trace_id的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论