aws xray如何实现应用log和trace的关联关系

参考资料

ecs容器环境下应用生成的trace信息没有log关联,但是在lambda环境中测试时发现可以进行关联

检查发现,trace的rawdata中存在aws的cwlog字段

在控制台查看网络请求,此时会向cloudwatchlog服务发送log insight请求

当我们在控制台点击跳转到loginsight时,语句如下。

复制代码
fields @log, @timestamp, @message
| filter @message like "1-66570681-3cb9b1bc917ab87c3dd8b303" or @message like "665706813cb9b1bc917ab87c3dd8b303"
| sort @timestamp, @message desc

经过以上步骤我们对两个问题有所了解

  • xray如何找到日志组?通过aws.cloudwatch_log属性
  • log如何呈现在xray控制台?通过发送loginsight的xhr请求

那么,接下来我们需要考虑如何在ecs应用中实现以上条件。参考链接(https://stackoverflow.com/questions/76000811/search-cloudwatch-logs-for-aws-xray-trace-id-in-code)中的说明

For API Gateway, Lambdas, the application logs group name are embedded in X-Ray traces out of box, so you don't need to do anything specially.

For the trace Id injection to application logs, today it is only supported by X-Ray/OTel Java SDKs. For Javascript applications, you'll need to inject and print X-Ray trace ids AWS-XRAY-TRACE-ID: 1-5d77f256-19f12e4eaa02e3f76c78f46a to your application log entries yourself.

对于条件1,我们需要编辑segment,加入aws.cloudwatch_log属性

对于条件2,我们需要在log内容中注入traceID

参考链接(https://blog.csdn.net/sinat_41567654/article/details/129317614)中的步骤创建xray和ecs集成环境,加入以下额外逻辑

  • 在segment中加入aws.cloudwatch_log属性
  • 模拟输出了一条日志并嵌入traceID
js 复制代码
app.get('/', (req, res) => {
    var document = AWSXRay.getSegment();
    // 加入aws.cloudwatch_log属性
    document.aws.cloudwatch_logs = [
        {
            "log_group": "/ecs/ecs-xray-demo-fargaet"
        }
    ]
    traceId = document.trace_id;
    console.log(document)
    // 模拟输出了一条日志并嵌入traceID
    console.log("2019-09-10 18:58:30.844 [nio-5000-exec-4]  AWS-XRAY-TRACE-ID: " + traceId + " WARN 1 - Your logging message here")
})
app.use(AWSXRay.express.closeSegment());

查看ecs的应用日志如下,trace和log成功关联

查看xray服务的控制台成功实现关联

相关推荐
TG_yunshuguoji1 小时前
腾讯云代理商:OpenClaw 实战指南-用腾讯云CloudBase 自动化开发网站
服务器·云计算·腾讯云·openclaw
亚马逊云开发者13 小时前
更新个监控 Agent 要协调 200 个团队?Amazon ECS 托管守护进程终于把平台工程师从苦海里捞出来了
aws
亚马逊云开发者19 小时前
5 个 Agent 协同处理金融业务,我用 Kiro + AgentCore 半天就部署上线了
aws
AC赳赳老秦1 天前
OpenClaw阿里云部署实操:多Agent协同,打造云端自动化工作流
人工智能·阿里云·数据挖掘·自动化·云计算·deepseek·openclaw
亚马逊云开发者1 天前
我把 Claude Code 的 Token 费砍了 70%,只用了 SageMaker + 一个路由 Hook
aws
雨落Liy1 天前
OpenClaw 腾讯云一键更新后全面排障与恢复
云计算·vim·腾讯云
喵叔哟1 天前
3.【.NET10 实战--孢子记账--产品智能化】--.NET 10 核心新特性概览:运行时与 ASP.NET Core 10
云计算·asp.net·.net
圣殿骑士-Khtangc1 天前
Amazon CodeWhisperer 超详细使用教程:AWS 云原生 AI 编程助手上手指南
人工智能·ai编程·aws·编程助手·codewhisperer
Echo-J2 天前
WinDbg 双机调试(调试机为Windows11系统,被调试机为Windows7系统)
安全·网络安全·云计算·系统安全
翼龙云_cloud2 天前
亚马逊云代理商:如何在 AWS Lightsail 上一键部署 OpenClaw 私有化 AI 助手?
人工智能·云计算·aws·openclaw