标签 goroutine 下的文章

省下 10% CPU!Uber 揭秘 Go 栈扩容的隐秘代价

本文永久链接 – https://tonybai.com/2026/05/28/uber-reveals-hidden-cost-of-go-stack-growth-10-percent-cpu-savings

大家好,我是Tony Bai。

在顶级互联网巨头的底层架构中,性能优化绝不仅仅是写两段优雅的代码,而是一场“刀尖舔血”的硬核战争。

试想一下,如果你的公司拥有超过 200 万个 CPU 核心(Cores),且其中 65% 的微服务完全由 Go 语言驱动,会发生什么?在 Uber 这样的计算体量下,哪怕仅仅提升 1% 的 CPU 效率,每年都能为公司省下数百万美元的真金白银。

最近,Uber 基础架构团队在对核心服务进行性能 Profiling 时,抓出了一个隐藏极深的 CPU “吸血鬼”。这个内鬼既不是复杂的业务逻辑,也不是被千夫所指的垃圾回收(GC),而是 Go 语言引以为傲的并发基石——Goroutine 栈扩容(Stack Expansion)

在部分核心微服务中,仅仅是栈扩容(runtime.copystack)这一项底层操作,就吞噬了近 10% 的 CPU 资源!而在 Uber 全局 600 多个微服务大盘中,栈拷贝的平均成本也高达 3.9%(作为对比,代价高昂的 GC 平均成本约为 7.3%)。

面对如此惊人的性能黑洞,Uber 的工程师们没有选择向官方妥协。他们直接向 Go 运行时(Runtime)开刀,甚至手撕底层汇编代码,硬生生把这 10% 的 CPU 损耗压到了 0.0047%。不仅如此,他们还将研究成果反哺给 Go 官方社区(Issue #77893),正在推动 Go 语言栈分配机制的历史性进化。

今天,就让我们扒开 Go 运行时的源码,重走一遍 Uber 团队打赢这场性能保卫战的硬核之旅。

剖析“案发现场”:Go 栈扩容的阿喀琉斯之踵

熟悉 Go 的开发者都知道,Go 在全球范围内大杀四方的核心武器就是 Goroutine(协程)

为了实现极高的并发密度,Go 语言在设计上做了一个大胆的取舍:与传统的操作系统线程(OS Thread,如 pthread_create 动辄分配 2MB 或 4MB 的初始栈)不同,一个 Goroutine 的初始栈空间仅仅只有 2KB

这种设计的优势是极其明显的:你可以轻松在一台普通机器上拉起数十万甚至上百万个 Goroutine,而不用担心内存溢出(OOM)。但天下没有免费的午餐,如果你的函数调用层级过深,或者在函数内部声明了较大的局部变量,区区 2KB 的栈空间瞬间就会被撑爆。

当 2KB 不够用时,Go 会怎么做?

Uber 团队在博客中深入解释了这一机制:Go 编译器会在每个函数的序言(Prologue)阶段插入一段检查指令,对比当前的栈指针(Stack Pointer)是否超过了阈值。


用于演示栈扩展过程的示例汇编代码

第 2 行展示了堆栈指针的值。如果该值超过了阈值,程序就会跳转到 runtime.morestack 函数进行处理。

一旦触发 runtime.morestack,Go 运行时会执行以下昂贵的操作:

  1. 申请一块原栈空间两倍大(即 4KB)的新内存。
  2. 调用 runtime.copystack,将旧栈的数据原封不动地“拷贝”到新栈中。
  3. 极其复杂的一步:更新旧栈中所有指向局部变量的指针,确保它们指向新栈的正确内存地址。
  4. 释放 2KB 的旧栈。

如果 4KB 依然不够呢?那就继续分配 8KB、拷贝、释放;再分配 16KB、拷贝、释放……

在 Uber 复杂的微服务链路中(比如处理庞大的 gRPC 请求、复杂的序列化/反序列化中间件),一个请求进来,往往需要数十 KB 的栈空间。这意味着每次请求都会触发多次徒劳无功的“搬家行为”。在峰值流量下,无数个 Goroutine 都在疯狂扩容,最终导致 CPU 算力被海量的内存拷贝白白挥霍。

为什么 Go 1.19 的“自适应栈”彻底失效了?

其实,Go 官方早就意识到了这个问题。在 Go 1.19 版本中,官方高调引入了一项优化:自适应栈大小(Adaptive Stack Size)

其设计初衷非常聪明:Go 会在每次垃圾回收(GC)扫描栈时,计算当前所有存活 Goroutine 的平均栈大小。如果当前程序的平均栈大小是 16KB,那么接下来新创建的 Goroutine 就会直接以 16KB 启动,完美避开 2KB -> 4KB -> 8KB -> 16KB 的拷贝地狱。

但这套看似完美的机制,在 Uber 真实的业务场景下,却彻底崩溃了。

在向 Go 官方提交的 GitHub Issue #77893 中,Uber 工程师贴出了详细的统计数据。他们发现,微服务中的 Goroutine 栈分布并不是均匀的,而是呈现出典型的双峰分布(Bimodal Distribution)

  • 海量的“僵尸”协程:在 Uber 的任意一个实例中,通常会有数千个长时间存活的后台 Goroutine。比如监听配置更新的轮询、阻塞在网络 I/O 上的长连接、或是空闲的 gRPC worker。这些 Goroutine 存活了极长的时间(超过 190 分钟),但它们的栈极浅,通常只有 2KB 到 4KB。
  • 少数的“重装”协程:真正在干活的、处理活跃请求的 Goroutine 数量相对较少,但一旦被触发,它们的栈会迅速膨胀到 16KB 甚至 32KB 以上。

悲剧就此诞生。由于海量的“僵尸协程”疯狂拉低了全局平均值,导致 Go 运行时计算出的平均栈大小永远在 4KB 左右徘徊。结果就是,那些真正需要处理复杂业务的新请求,依然只能以 4KB 悲惨开局,继续遭受 copystack 的毒打。

寻找解药:为什么常规优化方案行不通?

在明确了病因后,Uber 团队开始探索解决方案。

选择 1:Goroutine 池化(Goroutine Pooling)

这是很多高并发框架爱用的伎俩。Uber 内部的 M3 团队就曾使用过这个方案——让一堆固定数量的 Goroutine 常驻内存,任务来了就丢给它们执行。因为常驻协程已经扩容到了最大栈,所以不会再发生拷贝。

放弃原因:这需要对全公司的业务代码进行伤筋动骨的重构。协程池不仅增加了代码复杂度,还引入了 Channel 通信的额外 CPU 开销。如果在高负载下任务堆积,还容易导致系统死锁。

选择 2:手动摸石头过河(Manual Mode)

运维人员手动改代码,给服务分配 4KB 的初始栈,部署上去看 Profile;不行再改成 8KB,再部署……

放弃原因:完全不可扩展。Uber 有上千个微服务,靠人力试错无异于天方夜谭。

常规手段全部碰壁,Uber 的基础架构狂人们决定直接向 Go 运行时的底层规则发起挑战。

暴力美学:用黑魔法强改 Go 运行时变量

既然运行时的全局平均算法被后台“僵尸任务”带偏了,那我们就强行接管它!

然而,Go 官方并没有提供任何可以修改初始栈大小的公共 API(这是被隐藏在 runtime 包内部的机制)。为了打破这层封印,Uber 工程师动用了 Go 语言的终极黑魔法://go:linkname。

通过 go:linkname 这个编译器指令,Uber 成功绕过了包的可见性限制,强行将自己写的外部函数链接到了 runtime 内部的私有变量上。

同时,通过GODEBUG关闭了官方的自适应扩容和栈收缩逻辑(debug.gcshrinkstackoff = 1)。

这里还有一个插曲:由于滥用 linkname 会破坏语言的安全性,Go 官方在 Go 1.23 版本中严格限制了这一机制的使用。为了维持这个 Hack,Uber 甚至被迫在内部维护了一个对 Go 语言源码的 Patch(补丁),专门放开对 startingStackSize 变量的链接权限。

通过这一通硬核魔改,他们成功为不同的微服务通过配置下发(Runtime Environment Variables)注入了静态的初始栈大小。

这套暴力魔改的效果,堪称震撼:

当他们将某个核心请求链路的初始栈静态固定为 32KB 后:

  • CPU 吸血鬼被秒杀:runtime.copystack 的耗时从惊人的 39.98 秒(9.77%)垂直暴跌至 0.42 秒(0.0047%)
  • 整体算力大减负:整个容器的 CPU 实际消耗量直接下降了近 16%

从图中可见:部署了 32KB 静态栈补丁后,黄线(上周)与绿线(本周)的对比,CPU 使用率出现了明显的下降。

代价是什么?仅仅是容器多占用了不到 200MB 的物理内存(对于拥有 16GB 内存的微服务节点来说,这不到 2% 的内存开销简直是白送)。这就是系统级工程中典型的“空间换时间”神之一手。

全局扩展:自研汇编解析器,实现智能化预测

让一个服务吃上 32KB 很容易,但如何自动化地推断 Uber 旗下数百个微服务究竟需要多大的栈?

Uber 团队给出了一份教科书级别的“自动化性能反馈回路(Feedback Loop)”方案:

Uber 设计的自动化调整架构。从生产环境拉取 Profile -> 筛选出触发扩容的函数 -> 获取带符号表的二进制文件 -> 逆向反汇编计算栈大小 -> 将最优配置下发给微服务。

这里的技术难点在于:Profile 只能告诉你哪个函数触发了扩容,但它没法告诉你这个函数到底需要多大的内存。

Uber 的做法简直硬核到了极点:反汇编(Disassembly)。

他们编写了一个自动化工具,使用 Go 原生的 debug/elf 库解析带有符号表的二进制文件,找到那个罪魁祸首的函数,然后直接读取它的底层汇编指令!

在 x86 汇编中,函数在进入时会通过减小栈指针寄存器(RSP)来分配当前函数所需的栈帧空间。指令通常长这样:SUB $128, RSP。
Uber 的分析器精准地捕获这条指令,提取出立即数(比如 128 字节),然后沿着 Profile 的调用栈层层累加,最终极其精确地计算出这棵调用树在最深处到底需要多少物理内存!

通过这种“开天眼”般的方式,Uber 为每一个微服务量身定制了最完美的 2的次幂(如 8KB、16KB、32KB)作为静态启动栈,消灭了全公司的大部分的栈扩容内耗。

反哺开源:推动 Go 语言社区的历史性进化

Uber 并没有将这个每年能省下数百万美元的黑科技据为己有。

在验证了方案的巨大威力后,Uber 工程师带着详尽的生产级数据,敲开了 Go 官方 GitHub 的大门(Issue #77893),期望从语言底层寻找一种更优雅、无需魔改代码的终极解法。

这引起了 Go 核心开发团队(如 Keith Randall, thepudds)的高度重视。针对 Uber 揭示的“双峰分布”导致平均值失效的痛点,社区目前正在紧锣密鼓地测试几项革命性的补丁(如 CL 758141, CL 764220):

  1. 剔除“僵尸”协程(Filtering Inactive Goroutines):在计算全局平均栈大小时,直接把那些在过去一两个 GC 周期内完全没动过、一直阻塞在 Select 或 I/O 上的长时协程排除在数学公式之外。
  2. 放弃平均值,改用 P90 算法:不再使用易被极端值影响的平均数(Mean),转而追踪所有新销毁协程栈大小的 P75 或 P90 分位数。
  3. 内存阈值保护:为了防止盲目分配导致 OOM,Go 可能会引入一个软上限:只要预测的较大初始栈带来的额外内存开销,不超过程序总堆(Heap)大小的 1%,就允许新协程以更大的姿态启动。

Uber 工程师在他们的基础服务中测试了 Go 官方仍在 WIP(开发中)的“P90 + 剔除僵尸协程”补丁。结果令人振奋:在不写一行魔改代码的情况下,服务的 copystack 成本自动下降了高达 80%!

不出意外的话,在即将到来的 Go 新版本中,全球数以百万计的 Go 开发者,都将免费享受到由 Uber 趟出的这条性能优化之路。

小结:给高阶开发者的三个启示

从 Uber 这次优化战役中,我们应当汲取到系统级优化的深刻智慧:

  1. 没有永恒的银弹(No Silver Bullet):Go 的 2KB 极轻量级并发机制让它在网络编程中大杀四方,但在重度计算和深层中间件调用的微服务中,初始内存过小反而成了 CPU 杀手。理解底层的 tradeoff(空间换时间)是每一位高阶架构师的必修课。
  2. 让 Profiling 成为上帝之眼:如果 Uber 没有建立起常态化、Fleet-wide的 CPU Profiling 机制,这 10% 的算力损耗将永远隐藏在数据中心的嗡嗡作响中,无人知晓。性能优化,永远是数据驱动的。
  3. 敬畏底层,但也敢于重塑底层:遇到语言层面的严重瓶颈,平庸的工程师会说“官方机制就是这样,没办法”;但顶级的极客会直接打开源码,用 go:linkname 强行逆天改命,手撕机器汇编,最后再拿着硬核数据去推动官方修改世界规则。

技术的世界里永远没有绝对的黑盒,有的只是一次又一次在极限边缘的疯狂试探。今天,Uber 帮全球的 Go 开发者点亮了一盏明灯,而在不远的未来,这束光将照亮我们运行在云端的每一行代码。

资料链接:

  • https://www.uber.com/us/en/blog/zero-growth-stack
  • https://github.com/golang/go/issues/77893

还在为写 Agent 框架频频死循环、上下文爆炸而束手无策?我的新专栏 从0 开始构建 Agent Harness 将带你:

  • 抛弃臃肿框架,回归“驾驭工程 (Harness Engineering)”的第一性原理
  • 用 Go 语言手写 ReAct 循环、并发拦截与上下文压缩引擎等,复刻极简OpenClaw
  • 构建坚不可摧的 Safety Middleware 与飞书人工审批防线
  • 在底层实现 Token 成本审计、链路追踪与自动化跑分评估
  • 从“调包侠”进化为掌控大模型边界的“AI 操作系统架构师”

扫描下方二维码,开启从 0 开始构建Agent Harness 的实战之旅。


原「Gopher部落」已重装升级为「Go & AI 精进营」知识星球,快来加入星球,开启你的技术跃迁之旅吧!

我们致力于打造一个高品质的 Go 语言深度学习AI 应用探索 平台。在这里,你将获得:

  • 体系化 Go 核心进阶内容: 深入「Go原理课」、「Go进阶课」、「Go避坑课」等独家深度专栏,夯实你的 Go 内功。
  • 前沿 Go+AI 实战赋能: 紧跟时代步伐,学习「Go+AI应用实战」、「Agent开发实战课」、「Agentic软件工程课」、「Claude Code开发工作流实战课」、「OpenClaw实战分享」等,掌握 AI 时代新技能。
  • 星主 Tony Bai 亲自答疑: 遇到难题?星主第一时间为你深度解析,扫清学习障碍。
  • 高活跃 Gopher 交流圈: 与众多优秀 Gopher 分享心得、讨论技术,碰撞思想火花。
  • 独家资源与内容首发: 技术文章、课程更新、精选资源,第一时间触达。

衷心希望「Go & AI 精进营」能成为你学习、进步、交流的港湾。让我们在此相聚,享受技术精进的快乐!欢迎你的加入!

img{512x368}


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

大洗牌!Google 内部确认:Go 正取代 C++,成为 AI Agent 时代的“通用语言”

本文永久链接 – https://tonybai.com/2026/05/21/go-is-the-new-lingua-franca-for-ai-agents-at-google

大家好,我是Tony Bai。

在过去的两年里,只要一提到 AI 开发,99% 的人脑海中弹出的第一个词绝对是:Python。而如果是涉及到大模型底层的高性能推理与算力压榨,大家想到的必然是 C++ 或是 Rust

但在真正的工程落地中,情况正在发生一场令人猝不及防的剧变。

最近,Google 资深软件工程师 Jaana Dogan(@rakyll)在 X(原推特)上发布了一条引发技术圈热议的推文

“Go 成为 Google 内部 Agentic(智能体)系统的通用语言(lingua franca),这真的很了不起。我以前从未看到过 Go 有取代 C++ 的路径,但现在我相信这是可能的。”

这不仅仅是一条简单的技术感慨,它揭示了 AI 浪潮进入“下半场”后的核心工程困境:当我们把大模型封装成 Agent,并让成千上万个 Agent 并发协作时,Python 太脆弱,C++ 太沉重,而 Go,迎来了它的“天命时刻”。

今天,我们就来扒一扒,为什么 Google 会让 Go 接管 AI Agent 的底层开发?这对我们普通开发者的技术栈转型,又意味着什么?

打破滤镜:为什么 Python 和 C++ 在 Agent 时代“失宠”了?

要理解 Go 的上位,我们首先要搞清楚,AI Agent 到底需要什么样的工程能力。

现在的 AI 应用,早就不是早期那种“写个 Python 脚本,调用一下 OpenAI API,把结果打印出来”的玩具了。真实的 Agentic 系统(智能体系统)包含了极其复杂的网络 I/O、并发工具调用(Tool Calling)、多智能体消息路由、长时记忆状态管理,以及大规模的分布式容错。

在这个场景下,旧有的王者们暴露出了致命的缺陷:

1. Python 的“工程化陷阱”

Python 是 AI 研究员的最爱,因为它的数据科学库天下无敌。但当你要构建一个高并发、高可用、需要 24/7 运行的 Agent 编排系统时,Python 的弱类型(重构火葬场)和 GIL(全局解释器锁,导致无法真正利用多核并发)就成了灾难。正如原贴讨论区一位开发者所言:“模型层可能是 Python 的天下,但围绕着模型的 Runtime(运行时环境)正越来越像 Go 的领地。”

2. C++ 的“杀鸡用牛刀”

C++ 拥有极致的性能,是模型训练和推理引擎(Inner Loop)的绝对霸主。但 Agent 编排系统真的需要 C++ 级别的疯狂数学计算吗?不需要。

Agent 系统本质上是大量的网络等待(等 LLM 返回结果、等数据库查询、等网页抓取)。用 C++ 来写极其复杂的并发网络请求和状态机,不仅开发周期漫长,而且极易产生内存泄漏。正如推文评论所指出的:“C++ 背负了太多的历史包袱,它在 Agent 编排上显得太重了。”

Go 凭什么上位?Goroutine 与 Agent 的“完美同构”

Go 语言在这个时间节点爆火,并非偶然,而是因为它底层的并发哲学与 AI Agent 的行为模式产生了“完美的同构映射”

在 X 上的讨论中,多位资深开发者一针见血地指出了核心原因:

“Goroutines mapping directly to concurrent agent communication is the reason why it makes perfect sense.”(Goroutine 直接映射到并发 Agent 之间的通信,这是它如此完美契合的原因。)

让我们用大白话来翻译一下这个硬核逻辑:

什么是多智能体系统(Multi-Agent System)?本质上就是一堆各自独立的“数字员工”,它们一边自己干活,一边通过发消息相互沟通。
而 Go 语言最强大的杀手锏是什么?正是 CSP(通信顺序进程)并发模型,即 Goroutine(轻量级协程)和 Channel(通道)。

  • 当你启动一个 Agent 时:在 Go 里,你只需要一个简单的 go runAgent(),就能以极其低廉的内存代价(几 KB)启动一个并发实体。一千个 Agent?一万个 Agent?对 Go 来说毫无压力。
  • 当 Agent 之间需要协作对话时:你不需要去搞复杂的锁(Locks)或者共享内存,你只需要用 Go 的 Channel 把消息塞过去,另一个 Agent 就能安全地接收。

Agent 的编排,需要的是“轻量级的并发管理”,而不是“极致的数学计算速度”。这简直就是为 Go 量身定制的战场。

征服大厂,构建 Agent 架构的“铁三角”

除了并发模型上的天作之合,评论区的一位开发者还另外总结了 Go 赢下这场战争的另外三个决定性因素。他指出,现代 Agent 技术栈奖励三种特性,而 “Go 完美击中了这三点(Go nails all three)”

1. 强类型系统(Types):告别“盲盒”开发

Agent 系统中充斥着复杂的 JSON 解析、Tool Calling 的参数校验、以及结构化的输出。Python 的字典(Dict)传递在项目变大后就像是“盲盒”,你永远不知道里面缺了哪个字段。而 Go 的强类型 Struct 和极度清晰的错误处理机制(虽然大家都吐槽 if err != nil,但它确实极其可控),让系统拥有了极高的可预测性(Predictability)。

2. 极速的编译体验(Fast Builds)

“编译速度是让它成为绝配的原因之一。”在快速迭代的 AI 产品中,Go 那种秒级的编译速度,让开发者可以飞速地测试 Agent 的行为逻辑。相比之下,C++ 那漫长的编译过程在需要高频微调的 AI 时代显得格格不入。

3. 小巧的单一二进制文件(Small Binaries)

当你把 Agent 部署到云端、边缘设备甚至是 Serverless 环境时,Go 编译出来的是一个无需任何外部依赖的独立执行文件。没有 Python 烦人的环境依赖(无需折腾 pip, conda, 虚拟环境),直接丢进一个极小的 Docker 镜像中就能运行,这对于现代云原生运维来说是无可估量的优势。

一个反直觉的冷知识:大模型“最爱”写 Go 代码

推文中一个开发者提出了一个极其有趣且经常被忽视的视角:在 LLM(大语言模型)的眼中,Go 是一门完美的语言。

如果你经常用 Cursor/Codex/Claude Code等 写代码,你会发现一个现象:让 AI 写 Python,它经常会用错第三方库的版本;让 AI 写 C++ 或 Scala,它可能会搞出一堆极其复杂的继承、多态或者生命周期错误。

但如果你让 AI 写 Go 呢?成功率出奇的高。

原因在于:

  1. Go 的语法极致简单、无聊,甚至“没有类(Classes)”。它只有 Struct 和接口,这极大地减少了代码的“表面积(Surface Area)”。
  2. Token 使用率极高。由于没有复杂的黑魔法和繁琐的泛型体系(早期),LLM 在生成 Go 代码时不容易出现“幻觉”,维护起来极其容易。

在这个连代码本身都开始由 AI 生成的时代,“对 LLM 友好”竟然成了一门编程语言的核心护城河。

终局推演 —— C++ 守住“内环”,Go 赢下“外环”

那么,Go 真的会彻底消灭 C++ 吗?

并不完全是。这场讨论最终达成了一个非常清晰的技术栈共识:

“C++ still wins the inner loop. Go wins everything around it.”(C++ 依然赢得了内环,而 Go 赢得了周围的一切。)

未来的 AI 系统架构已经初露端倪,它将被清晰地划分为三个层级:

  1. 研究与数据层(Python):用于模型训练、数据清洗、算法验证。
  2. 算力内环(C++ / Rust / CUDA):大模型的推理引擎(如 vLLM、Ollama 底层)、张量计算。这里需要极致榨干每一滴 GPU 性能,C++ 依然是绝对的霸主。
  3. 编排外环与业务层(Go):这是距离普通开发者最近、也是市场需求最大的地方。成千上万的 Agent 调度、API 网关、并发的数据检索(RAG)、记忆数据库交互、工具链调用,全部都将被 Go 统治。

最新铁证!Google I/O 2026 震撼官宣:废弃旧路线,用 Go 重写 AI 核心入口!

如果你觉得前面硅谷大佬们的讨论还只是“理论推演”,那么在刚刚举办的 Google I/O 2026 大会上,Google 官方直接用一记雷霆手段,把这个趋势变成了既成事实。

Google 开发者博客发布了公告:正式宣布停止维护原有的 Gemini CLI,全面过渡到全新的“Google Antigravity(反重力)”多智能体开发平台,并推出全新的核心入口 —— Antigravity CLI

而在官方给出的技术变更文档中,最扎眼、最让 Go 开发者狂喜的一条更新理由,白纸黑字地写着:

“Faster execution: Built in Go, Antigravity CLI is snappier and more responsive.” (更快的执行速度:基于 Go 语言构建,Antigravity CLI 更加轻快、响应更迅速。)


图:Google I/O 2026:旧版 CLI,用Antigravity CLI替代

旧版的 Gemini CLI 是基于传统脚本语言(Node.js/TS 体系)构建的,在处理单点交互时绰绰有余。但 Google 明确表示,现在开发者的需求已经彻底变了:“你现在需要多个 Agent 相互通信、分工合作来解决复杂的系统问题。”

当单点 CLI 变成“多 Agent 协同编排后端”时,旧有的 JS/TS 体系在高并发、异步工作流(Asynchronous Workflows)和底层系统控制上面临性能瓶颈。Google 毫不犹豫地选择用 Go 语言 彻底重写,就是为了利用 Go 极致的并发和执行效率,来支撑起“后台多任务并发运行、且不锁定终端”的强悍体验。

小结:给开发者的生存建议

过去的一年里,无数后端开发者感到焦虑,觉得自己掌握的 CRUD 技能在 AI 面前一文不值。但 Google 内部的这场技术栈迁移,给我们指明了一条无比清晰的道路:

别再只盯着 Python 看了。

当 AI 从单一的对话框,走向全面接管企业业务流的多智能体(Multi-Agent)协作形态时,对高并发、高可用后端工程能力的需求不仅没有减少,反而呈指数级爆发。

学习 Go 语言,理解 Goroutine,掌握如何构建一个稳健的 Agent 编排框架。因为决定下一个十年 AI 应用成败的,不再是模型本身的算力,而是谁能最好地管理和协调这些拥有智能的“数字大军”。

而目前来看,Go,已经在这场战役中拔得头筹。

资料链接:https://x.com/rakyll/status/2056528039698403498


今日互动探讨:

你目前在开发 AI 应用或 Agent 系统时,使用的是什么语言?你是否遇到了 Python 在高并发或部署时的痛点?欢迎在评论区分享你的实战经验与踩坑血泪史,我们一起探讨 AI 时代的最佳实践!


还在为写 Agent 框架频频死循环、上下文爆炸而束手无策?我的新专栏 从0 开始构建 Agent Harness 将带你:

  • 抛弃臃肿框架,回归“驾驭工程 (Harness Engineering)”的第一性原理
  • 用 Go 语言手写 ReAct 循环、并发拦截与上下文压缩引擎等,复刻极简OpenClaw
  • 构建坚不可摧的 Safety Middleware 与飞书人工审批防线
  • 在底层实现 Token 成本审计、链路追踪与自动化跑分评估
  • 从“调包侠”进化为掌控大模型边界的“AI 操作系统架构师”

扫描下方二维码,开启从 0 开始构建Agent Harness 的实战之旅。


原「Gopher部落」已重装升级为「Go & AI 精进营」知识星球,快来加入星球,开启你的技术跃迁之旅吧!

我们致力于打造一个高品质的 Go 语言深度学习AI 应用探索 平台。在这里,你将获得:

  • 体系化 Go 核心进阶内容: 深入「Go原理课」、「Go进阶课」、「Go避坑课」等独家深度专栏,夯实你的 Go 内功。
  • 前沿 Go+AI 实战赋能: 紧跟时代步伐,学习「Go+AI应用实战」、「Agent开发实战课」、「Agentic软件工程课」、「Claude Code开发工作流实战课」、「OpenClaw实战分享」等,掌握 AI 时代新技能。
  • 星主 Tony Bai 亲自答疑: 遇到难题?星主第一时间为你深度解析,扫清学习障碍。
  • 高活跃 Gopher 交流圈: 与众多优秀 Gopher 分享心得、讨论技术,碰撞思想火花。
  • 独家资源与内容首发: 技术文章、课程更新、精选资源,第一时间触达。

衷心希望「Go & AI 精进营」能成为你学习、进步、交流的港湾。让我们在此相聚,享受技术精进的快乐!欢迎你的加入!

img{512x368}


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

如发现本站页面被黑,比如:挂载广告、挖矿等恶意代码,请朋友们及时联系我。十分感谢! Go语言第一课 Go语言进阶课 AI原生开发工作流实战 从 0 开始构建 Agent Harness Go语言精进之路1 Go语言精进之路2 Go语言第一课 Go语言编程指南
商务合作请联系bigwhite.cn AT aliyun.com
这里是 Tony Bai的个人Blog,欢迎访问、订阅和留言! 订阅Feed请点击上面图片

如果您觉得这里的文章对您有帮助,请扫描上方二维码进行捐赠 ,加油后的Tony Bai将会为您呈现更多精彩的文章,谢谢!

如果您希望通过微信捐赠,请用微信客户端扫描下方赞赏码:

如果您希望通过比特币或以太币捐赠,可以扫描下方二维码:

比特币:

以太币:

如果您喜欢通过微信浏览本站内容,可以扫描下方二维码,订阅本站官方微信订阅号“iamtonybai”;点击二维码,可直达本人官方微博主页^_^:
本站Powered by Digital Ocean VPS。
选择Digital Ocean VPS主机,即可获得10美元现金充值,可 免费使用两个月哟! 著名主机提供商Linode 10$优惠码:linode10,在 这里注册即可免费获 得。阿里云推荐码: 1WFZ0V立享9折!


View Tony Bai's profile on LinkedIn
DigitalOcean Referral Badge

文章

评论

  • 正在加载...

分类

标签

归档



View My Stats