标签 Gopher 下的文章

Go语言进入“后元老时代”?Ian Lance Taylor离职引发的思考:传承、创新与社区

本文永久链接 – https://tonybai.com/2025/05/11/ian-lance-taylor-leave-go

大家好,我是Tony Bai。

今天,Go 语言社区传来一个令人瞩目又略感“悲伤”的消息:Go核心团队的元老级人物 Ian Lance Taylor在为 Google 效力 19 年后,宣布离开。对于许多 Gopher 来说,Ian Taylor 的名字与 Go 语言的早期发展、GCC Go 前端 gccgo 的诞生,以及历时多年最终在 Go 1.18 实现的泛型设计紧密相连。

他的离开,不仅仅是一位资深工程师的职业变动,更像是一个时代的注脚,引发我们对 Go 语言发展阶段、团队演进以及开源项目生命力的深层思考。我们是否可以说,Go 语言正在步入一个“后元老时代”?这又意味着什么?在这篇文章中,我们就来简单聊聊。

一位“老兵”的自白与 Go 的变迁

在 Ian Taylor 的告别博文《Leaving Google》中,他回顾了自己从 2008 年加入 Go 团队(几乎与 Russ Cox 同期)至今的历程。他对自己角色的定位是:“追踪我所能追踪的关于项目的一切,并寻找需要帮助的领域。” 从为 GCC 添加 Go 前端以确保语言规范的清晰,到为 Google 内部构建系统和 SWIG 添加 Go 支持,再到推动泛型的落地,Ian Taylor 的贡献无疑是奠基性的

然而,最引人深思的是他对自己离开的解释:“Google has changed, and Go has changed, and the overall computer programming environment has changed. It’s become clear over the last year or so that I am no longer a good fit for the Go project at Google.” (谷歌变了,Go 也变了,整个计算机编程环境都变了。在过去一年左右的时间里,我已经越来越不适合谷歌的 Go 项目了。)

他还坦诚地剖析了自己的工作方式:“我能很快看到人们今天遇到的问题,以及他们明天会遇到的问题,并且我常常能够解决这些问题。但我迟迟未能看到那些能帮助人们做他们没有尝试去做、因此也没有错过的那些新事物的想法,比如 Go 模块代理和 Go 漏洞数据库。”

这段话意味深长。它似乎在暗示这么几点:

  • Go 项目的成熟:Go 已从最初“希望成为其他语言有用想法的范例”的探索期,成长为一个被广泛接受和使用的成熟语言。其面临的挑战和发展重心可能已从核心语言特性的打磨,转向生态系统的完善、开发者体验的优化以及应对更大规模应用的新需求。
  • 能力与阶段的匹配:Ian Taylor 所擅长的“解决已知和可预见问题”的能力,在项目早期至关重要。但随着项目的成熟,或许更需要能够预见和开创“用户尚未意识到其需求”的创新型人才。他提到的 Go module proxy 和 Go vulnerability database 正是这类创新的代表。
  • “新陈代谢”的必然:成功的开源项目如同生命体,核心团队成员的更迭是其发展过程中的自然现象。这并非衰落的信号,反而可能是项目适应新环境、焕发新活力的契机。

Go 语言的“后元老时代”:挑战与机遇并存

如果我们将 Go 的早期核心开发者(如 Rob Pike, Ken Thompson, Robert Griesemer, Russ Cox, Ian Lance Taylor 等)视为“元老”,那么随着时间的推移和人员的变动,Go 语言是否正在进入一个由新一代核心开发者主导,更加依赖成熟流程和广大社区贡献的“后元老时代”?

注:随着2024年Russ Cox将Go团队旗手的角色“让位”给Austin Clements,随着今天Ian Lance Taylor的离职,目前曾经的元老团队仅剩下Robert Griesemer一人还在Go核心团队一线为Go做着贡献。

我认为,这并非悲观的论调,而是对现实的客观描述,其中蕴含着独特的挑战与机遇:

传承

元老们奠定的设计哲学、简洁高效的文化基因、以及对工程实践的极致追求,是 Go 语言最宝贵的财富。如何在团队演进中确保这些核心价值不被稀释,并得到良好传承,是至关重要的。这需要完善的文档、清晰的设计原则、以及新核心成员对 Go 精神的深刻理解。

创新

Ian Taylor 的自省提醒我们,成熟项目也需要持续创新以避免僵化。他明确指出:“任何编程语言都不会‘完成’——编程环境总是在变化,语言必须进化,否则就会消亡。” 对于 Go 而言,未来的创新可能更多体现在:

  • 标准库的与时俱进:以适应新的编程范式和技术趋势(例如 AI/ML 对数据处理和并行计算的需求、云原生领域的新标准等)。
  • 工具链的智能化与易用性:如更好的调试工具、性能分析工具、更智能的 IDE 支持等。
  • 生态系统的拓展与治理:如何更好地支持和管理庞大的第三方库生态,确保质量和安全。
  • 拥抱新兴领域:在 AI 赋能开发、WebAssembly、IoT 等领域,Go 能否抓住新的增长点?

这些创新,可能需要不同于早期核心特性设计的思维模式和技能组合。

社区

随着 Go 的普及,其社区已经成为一支不可忽视的力量。在“后元老时代”,社区的角色可能愈发重要:
* 贡献的多元化:从代码贡献到文档撰写、Bug 反馈、布道推广,社区成员可以在各个层面参与。
* 人才的培养皿:许多未来的核心贡献者可能就来自于活跃的社区成员。
* 需求的反馈源:广泛的社区用户是检验语言特性和工具实用性的最佳试金石。
* 生态的共建者:第三方库的繁荣离不开社区的共同努力。

Ian Taylor 也表示“希望将来能再次为 Go 做出贡献”,这正体现了开源精神的魅力——即使离开官方团队,热爱和能力依然可以通过社区持续发光发热。

对我们 Gopher 的启示

Ian Lance Taylor 的离开,以及他对 Go 变迁的洞察,对我们每一位 Gopher 来说,都是一次宝贵的反思机会:

  1. 拥抱变化,持续学习:编程语言和技术环境在不断进化。作为开发者,我们需要保持好奇心和学习能力,跟上时代的步伐。
  2. 理解语言背后的哲学:学习一门语言,不仅要掌握其语法,更要理解其设计哲学和核心价值观。这有助于我们写出更“Go-idiomatic”的代码,并更好地参与社区讨论。
  3. 贡献的力量:无论能力大小,我们都可以通过各种方式为 Go 社区做出贡献。每一次提问、每一个 Bug 报告、每一篇分享,都是在为这个生态添砖加瓦。
  4. 思考个人与项目的匹配:Ian Taylor 的经历也提醒我们,个人职业发展需要考虑自身能力特点与项目/公司发展阶段的匹配度。

小结

Ian Lance Taylor 的离开,无疑是 Go 社区的一个损失,但更是 Go 语言走向更成熟、更开放阶段的一个标志。这不是一个时代的结束,而更像是一个新篇章的序曲。

Go 语言的未来,将由 Google 的持续投入、新一代核心开发者的智慧、以及全球数百万 Gopher 的共同努力来书写。

让我们向 Ian Taylor 致以崇高的敬意,感谢他为 Go 所做的一切!

传承不息,创新不止,社区共荣——这或许就是 Go 语言“后元老时代”最值得期待的图景。

  • Ian Taylor博文的地址:https://www.airs.com/blog/archives/670

Go的未来,你我共塑:聊聊你的看法

Ian Lance Taylor的离开标志着一个时代的节点,也开启了对Go语言“后元老时代”的无限遐想。你如何看待Go语言当前的演进阶段?在传承元老们奠定的基石之上,你认为Go在创新方面最需要突破的方向是什么?作为社区的一员,你又将如何参与到Go的未来建设中?

欢迎在评论区留下你的思考、祝福或任何想对Go社区说的话! 让我们一起见证并参与Go的下一个十年。

想与Go一同进化,系统把握语言精髓与未来趋势?

在Go语言迈入新发展阶段的今天,深刻理解其设计哲学、掌握核心原理、并洞察前沿创新(如AI与Go的结合)变得尤为重要。如果你渴望与Go一同成长,系统性地提升自己的技术认知,并与一群对Go充满热情的开发者深度交流…

那么,我的 「Go & AI 精进营」知识星球 正是这样一个为你搭建的平台!这里不仅有【Go原理课】带你追本溯源,【Go进阶课】助你技艺精进,【Go避坑课】让你从容应对挑战,更有关于Go未来发展方向的探讨和AI赋能的实践分享。我会亲自为你答疑解惑,你还能与众多优秀的Gopher思想碰撞,共同探索Go在“后元老时代”的无限可能。

立即扫码加入,与我们一起传承Go的优秀基因,拥抱创新,共建繁荣社区!

img{512x368}


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

Rob Pike的“抱怨”与Go的“解药”:直面软件膨胀的四大根源

本文永久链接 – https://tonybai.com/2025/04/27/rob-pike-on-bloat

大家好,我是Tony Bai。

今年年初,Go语言之父、UTF-8编码的发明者Rob Pike的一篇题为”On Bloat”(关于膨胀)的演讲幻灯片(在2024年下旬做的)在技术圈,尤其是在Hacker News(以下简称HN)上,引发了相当热烈的讨论。Pike作为业界泰斗,其对当前软件开发中普遍存在的“膨胀”现象的犀利批评,以及对依赖管理、软件分层等问题的深刻担忧,无疑戳中了许多开发者的痛点。

HN上的讨论更是五花八门,开发者们纷纷从自身经历出发,探讨“膨胀”的定义、成因和后果。有人认为膨胀是“层层叠加的间接性”导致简单修改寸步难行;有人认为是“不必要的功能堆砌”;还有人归咎于“失控的依赖树”和“缺乏纪律的开发文化”。

那么,Rob Pike究竟在“抱怨”什么?他指出的软件膨胀根源有哪些?而作为我们Gopher,Go语言的设计哲学和工具链,能否为我们从纯技术层面提供对抗膨胀的“解药”呢?今天,我们就结合Pike的演讲精髓和HN的热议,深入聊聊软件膨胀的四大根源,并从Go的视角尝试寻找一下应对之道。

“膨胀”的真相:远不止代码大小和运行速度

在深入探讨根源之前,我们需要认识到,“膨胀”并不止是字面意义上我们理解的最终编译产物的大小或者应用的运行速度慢,Pike的观点和HN讨论中的“软件膨胀”体现在多个维度:

  • 复杂性失控: 过度的抽象层次、复杂的依赖关系、难以理解的代码路径,使得维护和迭代变得异常困难。
  • 维护成本剧增: 添加新功能的长期维护成本(包括理解、测试、修复Bug、处理兼容性)远超初次实现的成本,但往往被低估。
  • 不可预测性与脆弱性: 庞大且快速变化的依赖树使得我们几乎无法完全理解和掌控软件的实际构成和行为,任何更新都可能引入未知风险。

下面我们具体看看Pike指出的“膨胀”几个核心根源:

根源一:特性 (Features) —— “有用”不等于“值得”

Pike 指出,我们不断地为产品添加特性,以使其“更好”。但所有特性都会增加复杂性和成本,而维护成本是最大的那部分,远超初次实现。他警示我们要注意“有用谬论” —— 并非所有“有用”的功能都值得我们付出长期的维护代价。

HN讨论也印证了这一点:功能冗余、为了匹配竞品或满足某个高层“拍脑袋”的想法而添加功能、甚至开发者为了个人晋升而开发复杂功能的现象屡见不鲜。

技术层面:Go的“解药”在哪?

  • 简洁哲学: Go从设计之初就强调“少即是多”,鼓励用简单的原语组合解决问题,天然地抵制不必要的复杂性。
  • 强大的标准库: Go 提供了功能丰富且高质量的标准库,覆盖了网络、并发、加解密、I/O 等众多领域,减少了对外部特性库的依赖。很多时候,“自己动手,丰衣足食”(使用标准库)比引入一个庞大的外部框架更符合Go的风格。
  • 关注工程效率: Go的设计目标之一是提高软件开发(尤其是大型项目)的工程效率和可维护性,这促使Go社区更关注代码的清晰度和长期成本。

注:技术层面包括语言、工具以及设计思路和方法。

根源二:分层 (Layering) —— 在错误的层级“打补丁”

Pike 认为,现代软件层层叠加(硬件 -> 内核 -> 运行时 -> 框架 -> 应用代码),当出现问题时,我们太容易在更高的层级通过包装(wrap)来“修复”问题,而不是深入底层真正解决它。这导致了层层叠叠的“创可贴”,增加了复杂性和维护难度。他列举了ChromeOS文件App的例子,并强调要在正确的层级实现功能和修复

在HN的讨论中,有开发者描述的修改按钮颜色需要穿透17个文件和多个抽象层的例子,正是这种“错误分层”或“过度抽象”的生动体现。

技术层面:Go的“解药”在哪?

  • 小接口哲学: Go 鼓励定义小而专注的接口,这使得组件之间的依赖更清晰、更松耦合。当问题出现时,更容易定位到具体的接口实现层去修复,而不是在外部层层包装。
  • 组合优于继承: Go 通过组合(struct embedding)而非继承来实现代码复用,避免了深度继承带来的复杂性和脆弱性,使得在“正确层级”修改代码更易操作。
  • 显式错误处理: if err != nil 的模式强制开发者在调用点处理错误,使得问题更难被“隐藏”到上层去统一“包装”处理,鼓励在错误发生的源头附近解决或添加上下文。

根源三:依赖 (Dependencies) —— 看不见的“冰山”

这是Pike演讲中着墨最多、也最为忧虑的一点。他用数据(NPM 包平均依赖 115 个其他包,每天 1/4 的依赖解析发生变化)和实例(Kubernetes 的复杂依赖图)强调:

  • 现代软件依赖数量惊人且变化极快。
  • 我们几乎不可能完全理解自己项目的所有直接和间接依赖。
  • 依赖中隐藏着巨大的维护成本、Bug 和安全风险
  • 简单的 npm update 或 audit 无法解决根本问题

他强烈建议要理解依赖的成本严格、定期地审视依赖树,并推荐了 deps.dev 这样的工具。

HN 社区对此深有同感,纷纷吐槽“为了一个函数引入整个库”、“脆弱的传递性依赖”、“供应链安全”等问题,并呼唤更好的依赖分析工具。

技术层面:Go的“解药”在哪?

  • Go Modules: 相比 NPM 等包管理器,Go Modules 提供了相对更好的依赖管理机制,包括语义化版本控制、go.sum 校验和、最小版本选择 (MVS) 等,提高了依赖的可预测性和安全性,但也要注意Go module并非完美
  • 强大的标准库: 这是 Go 对抗依赖泛滥的最有力武器。很多功能可以直接使用标准库,避免引入外部依赖。
  • 社区文化: Go 社区相对而言更推崇稳定性和较少的依赖。引入一个大型框架或过多的外部库在 Go 社区通常需要更充分的理由。
  • 工具支持: Go 提供了 go mod graph, go mod why 等命令,可以帮助开发者理解依赖关系。结合 deps.dev,可以在一定程度上实践 Pike 的建议。

根源四:开源模式 (Open Source Development) —— “大门敞开” vs “严格把关”

Pike 对比了两种开源开发模式:

  • “真正的开源方式” (The true open source way): 接受一切贡献 (Accept everything that comes)。他认为这是膨胀和 Bug 的巨大来源
  • 更好的方式: 设立严格的代码质量、标准、评审、测试、贡献者审查等“门槛”,对允许合入的内容有标准。这种方式维护成本低得多。

他暗示 Go 项目本身更倾向于后者,强调“先做好再提交”(make it good before checking it in)。可能很多Gopher也感受到了这一点,Go项目本身对代码质量的review非常严格,这一定程度上也“延缓”了一些新特性进入Go的时间点。

HN 的讨论中也涉及了类似 “Bazaar vs Cathedral” 的模式对比,但观点更加复杂,认为现实中的项目往往处于两者之间的某个位置,并且“完全不接受外部贡献”也并非良策。

技术层面:Go的“解药”在哪?

  • Go 自身的开发模式: Go 语言本身(由 Google 主导)的开发流程相对严谨,对代码质量和向后兼容性有较高要求,可以看作是“严格把关”模式的体现。
  • 标准库的设计: Go 标准库的设计精良、接口稳定,为开发者提供了一个高质量的基础平台,减少了对外部“随意贡献”的依赖。
  • 社区项目实践: 观察 Go 社区一些知名的开源项目,其贡献流程和代码标准通常也比较严格。

反思与现实:Go 也非万能,“警惕与纪律”仍是关键

虽然 Go 的设计哲学和工具链在对抗软件膨胀方面提供了许多“天然优势”和“解药”,但我们必须清醒地认识到,Go 语言本身并不能完全免疫膨胀

正如 Pike 在其“建议”(Advice) 中反复强调的,以及 HN 讨论中部分开发者指出的,最终软件的质量很大程度上取决于开发者和团队的“警惕与纪律” (vigilance and discipline)

  • 我们是否真正理解并避免了增加不相称成本的特性
  • 我们是否努力在正确的层级解决问题
  • 我们是否审慎地评估和管理了每一个依赖
  • 我们是否坚持了高标准的开发和评审流程

如果缺乏这些,即使使用 Go,项目同样可能变得臃肿、复杂和难以维护。同时,HN 讨论也提醒我们,软件膨胀背后还有更深层次的组织、文化和经济因素,这些往往超出了单纯的技术和开发者纪律所能解决的范畴。

小结:拥抱 Go 的简洁,但需务实前行

Rob Pike 的“抱怨”为我们敲响了警钟,Hacker News 的热议则展现了软件膨胀问题的复杂性和普遍性。它确实是我们在工程实践中需要持续对抗的“熵增”现象。

Go 语言以其简洁、显式、组合的设计哲学,以及强大的标准库和相对稳健的依赖管理,在技术层面上,为我们提供了对抗膨胀的有力武器。理解并拥抱这些 Go 的“基因”,无疑能在一定程度上帮助我们构建更健康、更可持续的软件系统。

当然,Pike 的观点也并非金科玉律。有批评者指出,他的视角可能带有一定的“NIH(非我发明)倾向”,并且存在两个关键的“盲点”:

  1. 忽视了“不使用依赖”同样是巨大的技术债。 每一行自写的代码都需要永远维护。
  2. 现实中的选择往往不是“使用依赖 vs 自己实现”,而是“使用依赖 vs 根本不做这个功能”。 面对复杂的合规要求(如 ADA、GDPR)、第三方集成或 FIPS 认证等,从零开始构建的成本(可能需要数百人年)往往让“自己实现”变得不切实际。为了让产品能够及时上线并满足用户(哪怕是 Pike 本人可能也在使用的“缓慢”网站)的需求,引入依赖和一定的“膨胀”有时是必要且务实的选择。

注:“NIH(非我发明)倾向”是一种心理现象,指的是人们对他人提出的想法或创新持有偏见,通常因为这些想法不是自己发明的。这种倾向使得人们倾向于低估或拒绝其他人的创意,尽管这些创意可能是有价值的。

这种批评也提醒了我们,虽然 Pike 对简洁和纪律的呼吁值得我们高度重视,但在真实的商业环境和复杂的工程约束下,我们必须做出务实的权衡。纯粹的技术理想有时需要向现实妥协。

最终,我们每一位 Gopher 都需要在理解 Go 简洁之道的同时,保持批判性思维和务实态度。 在日常的每一个决策中,审慎地权衡简单与复杂、理想与现实、引入依赖与自主掌控,才能在这场与“膨胀”的持久战中,找到最适合我们项目和团队的平衡点,交付真正有价值且可持续的软件。

你如何看待 Rob Pike 对软件膨胀的观点?你认为他的批评切中要害,还是忽视了现实的复杂性?欢迎在评论区分享你的思考与实践!

参考资料

  • Rob Pike – On Bloat – https://docs.google.com/presentation/d/e/2PACX-1vSmIbSwh1_DXKEMU5YKgYpt5_b4yfOfpfEOKS5_cvtLdiHsX6zt-gNeisamRuCtDtCb2SbTafTI8V47/pub?slide=id.p
  • HN:On Bloat – https://news.ycombinator.com/item?id=43045713
  • Pike is wrong on bloat
  • On Bloat – https://commandcenter.blogspot.com/2025/02/on-bloat-these-are-slides-from-talk-i.html

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

如发现本站页面被黑,比如:挂载广告、挖矿等恶意代码,请朋友们及时联系我。十分感谢! 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