当前位置: 首页 > news >正文

阿里云可观测联合 Datadog 发布 OpenTelemetry Go 自动插桩工具

作者:杨易(青风)

在云原生可观测性领域,OpenTelemetry 已经成为事实上的标准。相比于 Java 拥有成熟的字节码增强技术,Go 语言作为静态编译型语言,长期以来缺乏一种成熟、低侵入的自动插桩方案。目前的现有方案主要有:

  1. eBPF:功能强大但主要偏向系统调用层面,对应用层上下文(如 HTTP Header 传播)的处理较为复杂。
  2. 手动埋点:代码改动大,维护成本高,不仅要改业务代码,还得改依赖库的调用方式,显式地在各个关键节点添加 Trace 和 Metrics 逻辑。

为此,阿里云可观测团队和程序语言团队探索了 Go 编译时插桩解决方案,并将其核心能力捐赠给 OpenTelemetry 社区,形成了 opentelemetry-go-compile-instrumentation[1]项目。在和 Datadog、Quesma 等公司的共同努力下,我们发布了首个预览版本 v0.1.0[2]

工作原理

自动插桩工具的核心在于利用 Go 编译器的-toolexec参数。-toolexec会拦截 Go 编译命令,替换成我们的插桩工具。这样,在代码被编译之前,我们就有机会对它进行分析和修改。整个过程可以概括为两个阶段:

1. 依赖分析

在编译开始前,工具会分析应用的构建流程(go build -n),识别出项目中使用的第三方库如net/http, grpc,redis等。然后,它会自动生成一个文件otel.runtime.go,将对应的 Hook 代码(监测逻辑,后面用 Hook 代码表示)引入到构建依赖中。

2. 代码注入

当编译器处理目标函数时,工具利用-toolexec拦截编译,然后修改该目标函数的代码,在函数入口插入一段蹦床代码(Trampoline Code),蹦床代码会跳转到预先写好的 Hook 函数中。

  • 进入函数前(Before):Hook 记录开始时间,提取上下文信息(如 HTTP Headers),启动 Span。
  • 函数执行:执行原有的业务逻辑。
  • 退出函数后(After):Hook 捕获返回值或 Panic,结束 Span,记录耗时。

这种方式的优点是零运行时开销(除了必要的监测逻辑执行时间),因为插桩是直接编译进二进制文件的,不需要像 eBPF 那样在内核态和用户态之间切换,也不需要像 Java Agent 那样在启动时加载。

HTTP 插桩示例

让我们通过一个简单的 HTTP 例子来看看它是如何使用的。

package main import ... func main() { http.HandleFunc("/greet", func(w http.ResponseWriter, r *http.Request) { w.Write([ ]byte("Hello, OpenTelemetry!")) }) log.Fatal(http.ListenAndServe(":8080", nil)) }

手动插桩

需要手动引入 OpenTelemetry SDK,手动创建 Tracer,在 Handler 里手动 Start 和 End Span。

package main import ... func initTracer() func(context.Context) error { /* ...几十行初始化代码... */ } func main() { // 1. 初始化 Tracer shutdown := initTracer() defer shutdown(context.Background()) // 2. 包装 Handler handler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { // 3. 手动提取 Context,开始 Span tracer := otel.Tracer("demo-server") ctx, span := tracer.Start(r.Context(), "GET /greet") // 4. 确保结束 Span defer span.End() // 5. 可能还需要手动记录属性 span.SetAttributes(attribute.String("http.method", "GET")) w.Write([]byte("Hello, OpenTelemetry!")) }) // 6. ListenAndServe 也可能需要包装... log.Fatal(http.ListenAndServe(":8080", handler)) }

对于成百上千个接口的微服务,这种改造成本是灾难性的。

自动插桩

  1. 下载工具:到 Release 页面[2]下载
  2. 编译应用:./otel-linux-amd64 go build -o myapp
  3. 配置运行:export OTEL_EXPORTER_OTLP_ENDPOINT="http://localhost:4317" export OTEL_SERVICE_NAME="my-app"./myapp

编译器会默默地将 HTTP 请求的监测逻辑“织入”到应用二进制文件中。配置好 OpenTelemetry 的导出端点(如 Jaeger 或控制台),运行生成的 server。访问 /greet 接口时, Tracing 数据已经自动生成并上报了,包含了请求路径、耗时、状态码等信息。

从商业化到开源

我们在深度实践 eBPF 技术的过程中,虽然认可其强大,但也发现它难以完美处理应用层上下文。更重要的是,我们不断听到用户反馈,大家对繁琐的手动埋点和高昂的维护成本感到困扰。

为了解决这个痛点,我们开始探索 Go 编译时自动插桩方案,将其上线至阿里云可观测 ARMS 产品[3],在这片最严苛的“试验田”里不断迭代,逐步演化成一套成熟的解决方案,不仅能实现零代码修改的链路追踪,还扩展支持了丰富的指标统计、Runtime 监控乃至持续剖析等高级功能,甚至还可以通过自定义扩展的功能完成对企业内部 sdk 的埋点[4]

调用链分析

持续剖析

这套方案在电商、短剧、AI 视频、汽车等众多领域客户处得到了成功验证。在看到它为用户带来巨大价值、并验证了其稳定性和可行性后,我们决定将其核心能力贡献给 OpenTelemetry 社区,希望它能成为一个普惠的技术。同时,我们与可观测领域的顶尖厂商 Datadog 协作,共同推进,最终促成了这个官方项目[1]的诞生。

目前项目处于活跃开发阶段,欢迎大家试用、反馈并参与贡献,共同构建更美好的云原生可观测生态。

相关链接:

[1] OpenTelemetry Go 编译插桩项目

https://github.com/open-telemetry/opentelemetry-go-compile-instrumentation

[2] Release 链接

https://github.com/open-telemetry/opentelemetry-go-compile-instrumentation/releases/tag/v0.1.0

[3] 阿里云 ARMS Go Agent 商业版

https://help.aliyun.com/zh/arms/application-monitoring/user-guide/monitoring-the-golang-applications

[4] 自定义扩展

https://help.aliyun.com/zh/arms/application-monitoring/use-cases/use-golang-agent-to-customize-scalability

http://www.jsqmd.com/news/284866/

相关文章:

  • 科研必备工具:9款AI查重软件横向对比与使用技巧
  • 论文查重终极方案:9大AI软件排名及改写技巧详解
  • 阿克苏地拜城乌什阿瓦提柯坪英语雅思辅导机构推荐,2026权威出国雅思课程口碑排行榜
  • 2026年1月房产中介管理系统评测
  • RNN
  • IPD项目计划怎么写:全阶段里程碑、交付物与评审节奏
  • 塔城塔城乌苏额敏沙湾托里英语雅思辅导机构推荐,2026权威出国雅思课程中心学校口碑排行榜
  • 2026年高端水包砂生产厂家TOP5推荐:五大液态石材领域厂家专精典范
  • Sprint(冲刺)解读
  • Sprint(冲刺)解读
  • 硬核开源!AgentCPM重新定义端侧智能天花板,4B参数碾压30B性能,附一键部署教程
  • 二维码链接到视频,怎么方便分享才更有效?
  • javascript Map是什么_与对象有什么区别【教程】
  • 哲讯科技:以半导体SAP之道,铸就中国“芯”时代的智能基石
  • 哲讯科技:以半导体SAP之道,铸就中国“芯”时代的智能基石
  • RAG 为什么总是“看起来能用,实际不好用”?
  • 小型精密CNC车床/数控车床哪家好?2026年优质代理商深度评测
  • 2026年冠金石生产厂家TOP5权威推荐:上海岩首领航高端仿石漆新纪元
  • 【2026最新】SQL 三种注入方式详解,零基础入门到精通,收藏这一篇就够了_sql注入
  • 2026年冠金石生产厂家TOP5权威推荐:上海岩首领航高端仿石漆新纪元
  • 塔城塔城乌苏额敏沙湾托里英语雅思辅导机构推荐,2026权威出国雅思课程口碑排行榜
  • C++虚函数实现原理深度解析:从多态到底层机制
  • 2026年轴流风机厂家最新推荐:防爆轴流风机/防腐轴流风机/高压轴流风机/sfb轴流风机/sf轴流风机/wf屋顶轴流风机/选择指南
  • 2026 英语雅思网课一对一辅导平台排行榜:高性价比提分机构权威推荐​
  • 网络安全入门:什么是网络安全?为何它关乎每个人的数字生活?
  • YOLOv8-Pose 姿态识别 RK3588 实战:从模型训练到 RKNN 部署,精度与推理速度双提升
  • 2026年屋顶、隧道、边墙、混流、排烟风机十大品牌推荐:多区域实力企业务实之选
  • YOLOv13 全面教程:MogaBlock 模块原理深度解析与实战修改(手把手教学)
  • 全域网络安全防御 健全网络安全防护体系
  • 导师严选2026 AI论文平台TOP9:继续教育写作全攻略