登录
首页 >  Golang >  Go问答

如何使用json传递opentracing数据

来源:stackoverflow

时间:2024-04-09 18:12:38 427浏览 收藏

知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《如何使用json传递opentracing数据》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

问题内容

我的 api 网关启动一个跟踪器和一个用于验证电子邮件的范围。然后将其传递给 user-service 进行验证。

我想将此 span 详细信息作为 json 对象传递给 user-service 并启动另一个 span 作为

tracer.start_span('验证电子邮件', child_of=api_gateway_span)

为此,我使用了以下结构:

type checkemail struct {
    gatewaytracerspan opentracing.spancontext `json: gatewaytracerspan`
    email             string                  `json: email`
    uuid              string                  `json: uuid`
}

function()

validateEmailSpan := apitracer.tracer.StartSpan("Validate Email")

emailJson := checkEmail{
            GatewayTracerSpan: validateEmailSpan.Context(),
            Email:             email,
            Uuid:              uuid,
        }

gatewaytracerspan 始终为空值。 我刚刚开始分布式跟踪。在这里,我选择使用 json 而不是本机 http-headers,因为它可以轻松升级任何协议更改。

这可能吗?如果是这样,我这样做对吗?或者我犯了什么错误?


解决方案


链接来自不同服务的跨度的一种方法是使用父跨度中的 uber-trace-id。如果您在 reporterconfig 中将 logspans 设置为 true,则打印出的内容为 uber-trace-id ("reporting span xxx-xxx-xxx")。

代码如下:

//api gateway
carrier := opentracing.textmapcarrier{} //you can use any type of carrier or even create your own
ctx, _ := opentracing.globaltracer().extract(opentracing.textmap, carrier)
span := apitracer.tracer.startspan(name, ext.rpcserveroption(ctx))
_ := span.tracer().inject(span.context(), opentracing.textmap, carrier)
ubertraceid := carrier["uber-trace-id"]

您现在可以将 ubertraceid 而不是 validateemailspan.context() 传递给您的其他服务。

您可以在其他服务中使用此功能:

//email service
func newchildspanthatfollows(name, ubertraceid string) opentracing.span {
    carrier := opentracing.textmapcarrier{}
    carrier.set("uber-trace-id", ubertraceid)
    ctx, _ := opentracing.globaltracer().extract(opentracing.textmap, carrier)
    span := opentracing.startspan(name, opentracing.followsfrom(ctx))
    _ := span.tracer().inject(span.context(), opentracing.textmap, carrier)

    return span
}

如果我需要查看以父子方式链接在一起的服务之间的跨度,这对我有用。如果还需要传递其他信息,我建议将其作为 json 对象中的常规数据传递,然后创建我自己的 carrier 或使用标签(如果需要)对传递的数据进行搜索。

span.SetTag("request_id", requestID)

编辑:

Here 您可以找到有关使用 opentracing 的精彩教程。它使用httpheaderscarrier,它有一步一步的演练,但基本上与上面的过程相同。

理论要掌握,实操不能落!以上关于《如何使用json传递opentracing数据》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>