Go Command 工作组成立:这几个用了十年的命令可能要被废!

本文永久链接 – https://tonybai.com/2026/04/11/go-command-working-group-formed-legacy-commands-deprecated

大家好,我是Tony Bai。

在这个技术浪潮汹涌的时代,Go 语言以其惊人的稳定性和向后兼容性著称。但稳定,并不代表停滞。

就在最近,Go 核心团队内部悄然发生了一件大事:他们正式成立了一个全新的 “Go Command 工作组(Go Command Working Group)”。

这个工作组汇聚了 Go 工具链领域最核心的大神们(如 Cherry Mui、Matloob、ThePudds 等)。他们的使命非常明确:对 go 命令集中那些最古老、最含糊、最容易引发开发者困惑的“历史遗留问题”,进行一次彻底的“清理门户”。

就在前几天,这个“指挥部”的前两次闭门会议纪要,以及随之而来的两份重磅提案(Issue #78350#78387被公之于众。

当我读完这些提案和讨论后,我意识到,一场关于 Go 语言未来的“静默革命”已经打响。今天,就让我们来拆解这场顶级大佬的闭门会议,看看我们用了十年的几个“祖传命令”,为什么即将面临被废除的命运。

第一刀:砍向 go list …,这个“万能匹配”为何成了大坑?

如果你写过稍微复杂一点的 Go 项目,甚至只是写过一些 Makefile,你大概率见过 go list …。

在早期,go list …中的这三个点的省略号 … 意味着“匹配所有(Everything)”。

但在 Go Modules 时代,这条命令成了一个彻头彻尾的“陷阱”。

在最新的 Issue #78387 提案中,工作组负责人 Matloob 毫不客气地指出:

“在Go 模块模式下,go list … 几乎永远做不出用户期望它做的事!”

大佬辩论现场还原:

  • Matloob(主刀人):它试图列出构建列表中所有模块的所有包,这会导致解析一大堆根本不需要的依赖。如果直接在模块下运行,它甚至会因为找不到工作区依赖而直接抛出莫名其妙的错误。
  • PJ Weinberger:强烈支持(废弃)!
  • ThePudds模块图剪枝(Pruning)在Go 1.17引入后,匹配模式的含义变得非常复杂,连文档都没完全跟上。大家越来越搞不懂 … 到底代表什么了。

为什么必须砍掉它?

在旧的 GOPATH 时代,go list … 能简单粗暴地列出 $GOPATH/src 下的所有包。但在 Modules 时代,你想要的其实是当前项目的所有包,也就是 go list ./…(注意前面的 ./)。

直接用 … 会引发漫长且无意义的全局依赖解析,甚至导致构建失败。

更有意思的是,核心成员 Sean Liao (seankhliao) 用 GitHub 搜索了一下,发现有将近 6700 个 Makefile 或脚本里还写着 …。但经过抽查发现,这些代码大多是从几年前的旧教程里复制粘贴过来的,实际上在现在的模块模式下,它们本来就已经跑不通了。

经过讨论,工作组达成初步共识:在模块模式下,直接使用 go list … 将会报错并被禁用。系统会提示你改用 ./… 或者 work 模式。如果你公司的古老 CI 脚本里还有这个写法,赶紧改!

第二刀:GO111MODULE=auto 的黄昏,彻底关上 GOPATH 的大门

GO111MODULE 这个环境变量,是无数 Gopher 从 GOPATH 时代痛苦过渡到 Modules 时代的“阵痛记忆”。

它有三个值:on(强制开启模块)、off(强制关闭)、以及 auto(自动检测)。

Issue #78350 提案中,工作组决定对 auto 下达最终的“死亡通知书”。

大佬辩论现场还原:

  • Matloob:我们提议,将 GO111MODULE=auto 的行为直接等同于 on。实际上这就是把它给“移除”了。
  • Cherry Mui(安全与数据派):我们应该现在就开启遥测(Telemetry),看看到底还有多少人在用 auto。我们无法预测什么时候会需要这些数据。
  • ThePudds(社区观察家):确实还有少数人,比如只想在命令行随手编译一个单文件脚本,不想建 go.mod 的人,还在享受 GOPATH 模式。

为什么必须砍掉 auto?

auto 的逻辑是:如果当前或上层目录有 go.mod,就用模块模式;否则就回退到 GOPATH 模式。

这种“左右摇摆”的行为在十年前是伟大的过渡方案,但在今天却成了巨大的累赘。

Go 的工具链在启动时,每次都要去猜自己到底在什么模式下运行。如果彻底砍掉 auto(即默认全局 on),编译器可以做大量的架构简化。

更有趣的是,在提案的评论区,有开发者表示他们为了在旧 GOPATH 项目和新 Modules 项目间切换,在全局环境变量里写死了 GO111MODULE=auto。

但 Go 团队的决心是坚定的:到了 2026 年,如果你真的还在维护古老的 GOPATH 项目,你应该显式地在那个目录下设置 GO111MODULE=off。默认情况下,大门已经向 GOPATH 彻底关闭。

第三刀:终结 go.mod 里的版本号“无意义内卷”

除了上述两个直接废弃的命令,会议纪要中还透露了一个极具前瞻性、也最能体现 Go 团队“工程哲学”的重磅提议:关于 go.mod 文件中 Go 版本号的简化。

如果你现在运行 go mod init my-module,生成的 go.mod 文件里会包含一个精确到补丁号(Patch version)的版本,比如 go 1.26.2。

这引发了一个极其无聊,却又在开源界反复上演的“内卷”:

每次 Go 发布一个新的小补丁版本,Github Dependabot 这种自动化机器人就会疯狂地给全世界的开源项目提 PR,要求把 go.mod 里的版本号也跟着升上去。

大佬辩论现场还原:

  • ThePudds:这种为了升级而升级的行为,带来了巨大的“噪音(Noise)”,却没有相应的收益。我们应该倡导一个最佳实践:默认情况下,go mod init 应该只生成主次版本号(如 go 1.26),补丁号应该是可选的且不推荐设置!
  • Cherry Mui(安全视角):等一下,这需要跟安全团队确认。如果某个补丁修复了严重的安全漏洞,漏扫工具会不会因为开发者没写补丁号而漏报?
  • ThePudds:每个开发者都有自己本地的构建工具链决策权。仅仅因为 Go 出了个补丁,并不意味着世界上每一个开源库都需要立刻被 Dependabot 强行更新一次 go.mod 文件。

go.mod 里的 go 指令,核心作用是“启用语言的语法特性”。只要你的代码没用新语法,写 1.26 就足够了。至于构建时到底用 1.26.3 还是 1.26.8 的编译器来保证安全,那是执行构建动作的人(或者 CI 系统)该操心的事,而不是由成千上万个基础库的 go.mod 文件来反向绑架。

这项提议一旦落地,将彻底终结无意义的 PR 轰炸,让开源维护者重新获得清净。

小结:一场“静默的革命”

Go Command 工作组的这两次会议,没有像泛型那样引入任何惊天动地的新语法。

但它对 Go 语言生态的影响,可能比任何一个新特性都要深远。

它像一个经验丰富的老园丁,正在小心翼翼但又果断地修剪 Go 这棵大树上那些已经枯萎、或者长歪了的枝桠。

  • 砍掉 go list …,是为了让模块查询的逻辑更清晰。
  • 砍掉 GO111MODULE=auto,是为了让构建环境更具确定性。
  • 简化 go.mod 的补丁号,是为了让整个生态的协作更高效。

在这场“静默的革命”背后,我们看到的,是 Go 团队对“简单性、确定性、工程效率”这三大工程哲学一以贯之的坚守。

Go 语言的伟大,不在于它有多么强大的功能,而在于它在过去十几年里,拒绝了多少看似“合理”的坏品味。而这场“清理门户”,才刚刚开始。

资料链接:https://github.com/golang/go/issues/78474


今日互动探讨:

在日常开发中,你被 Go 命令行的哪些“反直觉”行为坑过?对于废弃 go list … 和 GO111MODULE=auto,你是拍手叫好还是觉得会影响你的老项目?

欢迎在评论区分享你的看法!


还在为“复制粘贴喂AI”而烦恼?我的新专栏 AI原生开发工作流实战 将带你:

  • 告别低效,重塑开发范式
  • 驾驭AI Agent(Claude Code),实现工作流自动化
  • 从“AI使用者”进化为规范驱动开发的“工作流指挥家”

扫描下方二维码,开启你的AI原生开发之旅。


你的Go技能,是否也卡在了“熟练”到“精通”的瓶颈期?

  • 想写出更地道、更健壮的Go代码,却总在细节上踩坑?
  • 渴望提升软件设计能力,驾驭复杂Go项目却缺乏章法?
  • 想打造生产级的Go服务,却在工程化实践中屡屡受挫?

继《Go语言第一课》后,我的《Go语言进阶课》终于在极客时间与大家见面了!

我的全新极客时间专栏 《Tony Bai·Go语言进阶课》就是为这样的你量身打造!30+讲硬核内容,带你夯实语法认知,提升设计思维,锻造工程实践能力,更有实战项目串讲。

目标只有一个:助你完成从“Go熟练工”到“Go专家”的蜕变! 现在就加入,让你的Go技能再上一个新台阶!


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

Ruby on Rails 之父最新访谈:AI 正在推高顶尖程序员的身价

本文永久链接 – https://tonybai.com/2026/04/10/rails-father-dhh-on-ai-and-programmer-value

大家好,我是Tony Bai。

在这个由 AI 主导的、充满不确定性的 2026 年,整个软件行业似乎都被一种集体性的焦虑所笼罩。我们每天都在讨论:当 AI 能在一分钟内写完我们一周的代码时,我们这些“人类程序员”的价值还剩下多少?

就在所有人都在悲观地预测“程序员即将贬值”时,一位以“毒舌”和“极简主义”著称的硅谷大神,却逆着人潮,抛出了一个极其震撼的“反共识”暴论:

“我们可能已经见证了‘普通程序员’薪资的顶峰。但对于那些顶尖的、真正懂行的开发者来说,AI 正在让他们变得比以往任何时候都更值钱、更有价值。”

说出这句话的,正是 David Heinemeier Hansson (DHH)——Ruby on Rails 框架之父、37signals (Basecamp & HEY) 的联合创始人兼 CTO。

就在几个月前,DHH 还是 AI 编程最坚定的“喷子”之一。他曾公开嘲讽 Copilot 像个烦人的实习生,打断他的思路,生成的代码全是垃圾。

但在一场最新的深度访谈中,他却上演了一场惊天动地的“自我推翻”。他不仅承认自己已经“彻底投降”,更是将他现在的工作流形容为 “Agent First on Everything”(万物皆以智能体为先)

这场 180 度的惊天逆转背后,到底发生了什么?在这场信息量爆炸的对话中,DHH 不仅详细复盘了让他“觉醒”的那个“aha moment”,更对 AI 时代的程序员价值、团队协作、以及“软件匠艺”的未来,给出了极其深刻、甚至有些残酷的终极洞见。

从“令人作呕”到“欲罢不能”:DHH 的“觉醒”之路

DHH 坦言,在 Copilot 和早期 Cursor 的“代码补全(Autocomplete)”时代,他对此类工具的厌恶达到了顶峰。

“我感到无比愤怒。它总是在我还没想清楚的时候就试图猜我想写什么。‘你是想写这个吗?’‘你是想写那个吗?’ 闭嘴!让我自己把话说完!

他甚至一度悲观地认为,整个行业将走向一个由“Tab 键”驱动的、毫无思想的愚蠢未来,并开玩笑说自己可能要去丹麦种土豆了。

转折点发生在 2025 年的冬天。两个关键变量,彻底改变了游戏规则:

  1. 模型的质变:Anthropic 的 Claude Opus 4.5 模型发布。DHH 发现,这个模型生成的代码质量,第一次持续地、稳定地震惊到了他。它产出的代码,在很多时候,是他自己也愿意合并的。
  2. 交互范式的革命:以 Open Code 和 Claude Code 为代表的 Agent Harnesses出现。AI 不再是那个烦人的“代码补全机”,而是变成了一个可以独立使用工具(Bash、网络)、拥有自己终端的“数字同事”。

DHH 形容,当这两个变量结合在一起时,他迎来了职业生涯的“第二次启蒙”——上一次,是 2000 年初他第一次发现 Ruby 语言的优雅。

“我不再是那个在键盘上打字的人,我感觉自己像是穿上了一套超级机甲。我突然长出了 12 只手,可以同时操作 7 个屏幕。我作为程序员的能力,被极度放大了。

我们可能已经度过了“程序员薪资的顶峰”

当被问及 AI 是否会取代程序员时,DHH 毫不避讳地抛出了一个极其冷酷的观点:

我们很可能已经见证了“程序员(作为一种普通职业)”的黄金时代顶峰。

他认为,在过去,程序员之所以能获得极高的薪资,是因为他们是生产软件的“瓶颈资源”。产品经理想出一个绝妙的点子,必须排队等待昂贵的程序员花几周时间才能实现。

但现在,瓶颈正在快速转移。

“当产品经理自己就能用 AI 生成可用的代码时,事情就要变天了。在任何一个软件开发被视为‘成本中心’(而这恰恰是世界上绝大多数的软件开发场景)的公司,降薪和裁员的压力将是不可避免的。”

但这是否意味着所有程序员都会被淘汰?

恰恰相反。DHH 认为,AI 正在引发一场剧烈的“价值两极分化”

  • 中间层的崩溃:那些只会“把需求翻译成代码”的普通程序员,其价值正在被无限稀释。因为 AI 做这件事更快、更便宜。
  • 顶尖人才的价值飙升:那些具备极高“品味(Taste)”、“审美(Aesthetics)”和“架构判断力”的资深工程师,他们的价值正在被 AI 放大 10 倍甚至 100 倍。

因为他们是那个能够判断“AI 生成的东西是对是错、是美是丑”的最终把关人。他们从“体力劳动者”,进化为了“艺术总监”。

当 AI 能写所有代码,我们还剩下什么?

在这场对话中,DHH 反复强调一个词:Aesthetics is truth(美学就是真理)。

他认为,无论是在数学、物理学还是软件工程中,一个优美的解决方案,往往也正是那个正确的方案。

“乔布斯之所以关心 Mac 电脑机箱内部的走线,是因为他凭直觉知道,只有那些在乎印刷电路板布局的人,才会去死磕用户界面的每一个像素。

在 AI 时代,这种对“美”的追求,不仅没有过时,反而变得空前重要。

因为当你拥有了无限的“算力(AI)”时,唯一稀缺的,就是“品味(Taste)”

DHH 认为,未来顶尖的软件工程师,其核心竞争力将不再是“知道多少种排序算法”,而是:

  1. 产品感:深刻理解“我们应该做什么,不应该做什么”。
  2. 系统设计能力:将模糊的业务需求,抽象为清晰、优美的架构。
  3. 极高的审美标准:能够引导 AI 生成不仅能工作、而且看起来赏心悦目、易于维护的代码。

代码的实现,正在变得廉价;而代码的“品味”,正在变得无价。

大神的日常:我是如何指挥 AI “军团”的?

DHH 详细分享了他现在的“Agent-First”工作流,堪称教科书级:

他使用 tmux 在终端里创建了一个三分屏布局:

  • 左侧是 Neovim 编辑器。
  • 右上是跑着 Google Gemini 的 Open Code。
  • 右下是跑着 Claude Opus 的 Claude Code。

“我几乎所有的工作都从其中一个 Agent 开始。我给它一个模糊的指令,然后看着它生成初稿。然后我把初稿扔给另一个 Agent,让它去批判和重构。我让它们俩来回‘吵架’。最后,我再跳到 Neovim 里,做那个最终的‘裁判’。”

他分享了一个让他自己都感到震惊的案例:

37signals 的 Linux 发行版 Omarchy 积压了 250 个无人处理的 PR。他花了 90 分钟,让 Claude 帮他审完了其中 100 个。

  • 10% 直接合并。
  • 20% Claude 觉得思路对,但实现太烂,直接帮他重写了一版。
  • 剩下的大部分,要么被他判定为“不需要”,要么被 Claude 识别为“实现太差且没有好思路”,直接关闭。

“这在以前至少是一周的工作量。更重要的是,其中一半的 PR 涉及我不懂的领域,Claude 在那些领域,是比我更聪明、更优秀的审查者。”

野心的爆炸:探索一个直觉的成本,已被降低一千倍

DHH 在访谈中提到了一个极具启发性的概念:AI 正在让“雄心(Ambition)”变得廉价。

他举例,他让 Agent 在几天内,为一个搁置已久的需求(为 Omarchy 实现 Windows 双系统启动)制定了一套完整的、可执行的方案。而在过去,他连花 4 个小时去调研的意愿都没有。因为这件事“重要但不紧急”,而且“非常麻烦”。

“探索一个直觉的成本,已经被降低了一千倍。我们现在可以去挑战那些过去连想都不敢想的项目。”

他分享了 37signals 内部的一个真实案例:一位名叫 Jeremy 的工程师,利用 AI 发起了一个名为“P1 优化”的疯狂项目。他要去优化系统中那最快的 1% 的请求,让它们变得更快。

这在传统性能优化的世界里,简直是“吃饱了撑的”。

但 Jeremy 仅用了几天时间,通过让 Agent 疯狂分析和重构,提交了 12 个 PR,硬生生把这 1% 请求的延迟从 4ms 压缩到了 0.5ms 以下,实现了 10 倍的性能提升。

当探索的成本趋近于零时,过去那些被视为“无用功”的边缘优化,将共同汇聚成压倒性的产品优势。

小结:这是一场关于“手艺”的文艺复兴

在访谈的结尾,DHH 表达了他对未来的极度乐观。

他认为,AI 并没有让编程变得无趣,反而让他找回了自 2000 年初发现 Ruby 以来最大的快感。

DHH 的这场“觉醒”,不仅仅是一个技术大佬对新工具的拥抱。它更像一个宣言:

在 AI 时代,软件工程的“手艺(Craft)”并没有消亡,它只是从“雕琢代码”的微观层面,升维到了“塑造品味”与“驾驭系统”的宏观层面。

AI 正在无情地淘汰那些只会“拧螺丝”的码农,但同时,它也为那些真正热爱创造、拥有极高审美和品味的“工匠”,递上了一把前所未有的神兵利器。

你,准备好拿起它了吗?

资料链接:https://www.youtube.com/watch?v=JiWgKRgdgpI


今日互动探讨:

在使用 AI 编程后,你是否也像 DHH 一样,感觉自己的“野心”被放大了,敢于去挑战更复杂的项目?在你的工作中,AI 是更多地扮演“体力外包”,还是“创意伙伴”的角色?

欢迎在评论区分享你的真实感受!


还在为“复制粘贴喂AI”而烦恼?我的新专栏 AI原生开发工作流实战 将带你:

  • 告别低效,重塑开发范式
  • 驾驭AI Agent(Claude Code),实现工作流自动化
  • 从“AI使用者”进化为规范驱动开发的“工作流指挥家”

扫描下方二维码,开启你的AI原生开发之旅。


原「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原生开发工作流实战 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