如何承担 golang xray 客户端的角色?

时间:2021-07-09 17:58:28

标签: amazon-web-services go aws-xray aws-sdk-go

每个https://aws.amazon.com/xray/faqs/

Q: My application components run in their own AWS accounts. Can I use X-Ray to collect data across AWS accounts?
Yes, the X-Ray agent can assume a role to publish data into an account different from the one in which it is running. This enables you publish data from various components of your application into a central account.

我知道我可以担任这样的角色:

    st := sts.NewFromConfig(awsConf)
    creds := stscreds.NewAssumeRoleProvider(st, "myRoleArn")
    awsConf.Credentials = aws.NewCredentialsCache(creds)

我知道我可以使用这些凭据创建 xray 服务

    import xrayv2 "github.com/aws/aws-sdk-go-v2/service/xray" 
    xrayService := xrayv2.NewFromConfig(awsConf)

问题在于 xray 服务是为直接与 xray API 交互而设计的,它没有 xray 客户端提供的任何奇妙的魔法。 我知道的 xray 客户端是这样配置的:

    import "github.com/aws/aws-xray-sdk-go/xray"
    xray.Configure(xray.Config{
        DaemonAddr:                  "",
        ServiceVersion:              "",
        Emitter:                     nil,
        SamplingStrategy:            nil,
        StreamingStrategy:           nil,
        ExceptionFormattingStrategy: nil,
        ContextMissingStrategy:      nil,
        LogLevel:                    "",
        LogFormat:                   "",
    })

无论我使用的是 aws 还是 aws-v2 库,我都看不到可以向 xray 客户端提供任何类型的 aws conf/凭据提供程序的地方。我可以创建自定义发射器,但我希望避免这种情况。

关于如何向 github.com/aws/aws-xray-sdk-go/xray 提供凭据缓存的任何想法?

1 个答案:

答案 0 :(得分:0)

另一个 S.O.问题帮助我误解了我的误解。 AWS X-Ray 客户端库只是将信息发布到本地运行的守护程序。因此,代码不负责将痕迹传送到 X 射线。

按照此处的步骤操作 - https://aws.amazon.com/blogs/compute/application-tracing-on-kubernetes-with-aws-x-ray/

并设置此变量 _ = os.Setenv("AWS_XRAY_DAEMON_ADDRESS", "xray-service.kube-system:2000"),我们能够将库指向本地守护进程。

那么负责转发的是守护进程,因此我们通过覆盖 xray ConfigMap 中的 RoleArn 来覆盖守护进程正在运行的角色。