标签 Rust 下的文章

“我从未想过学完 Rust 后会转向 Go”—— 这门“无聊”的语言究竟有什么魅力?

本文永久链接 – https://tonybai.com/2025/12/07/switching-from-rust-to-go-appeal-of-the-language

大家好,我是Tony Bai。

“我从未想过在学习 Rust 之后,我还会转而学习 Go。”

近日,开发者 Abhishek Singh 的一条推文,以其独特的、充满“诗意”的笔触,在开发者社区引发了广泛的共鸣和讨论。这句自白之所以令人惊讶,是因为它描绘了一条在很多人看来“不可思议”的技术迁徙路径:从 Rust——一门以其严谨、强大、表达力丰富著称的现代语言,转向 Go——一门在许多人眼中“简单”、“啰嗦”甚至“无聊”的语言。

这篇充满矛盾感的推文,让我们不得不直面那个核心问题:当剥离了那些华丽的语言特性后,Go 这门看似“无聊”的语言,究竟隐藏着何种独特的魅力,足以让一位经历过 Rust 洗礼的开发者最终与之“和解”,甚至“像写诗一样”乐在其中?

本文,就让我们跟随这位开发者的心路历程,层层深入,一同探寻这个问题的答案。

“无聊”的表象,是可预测性的极致

Singh 在推文中这样描述 Go 的特质:“简单却不简陋,无聊却又令人兴奋”。让我们先来看“无聊”这一面。

对于习惯了 Rust 强大的 enum、模式匹配和 Trait 系统的开发者来说,Go 的世界确实显得有些“朴素”甚至“原始”。日常的编码,充斥着对 struct 的简单定义和一遍又一遍的 if err != nil。Go 缺乏许多现代语言中“炫技”的语法糖,这正是其“无聊感”的来源。

然而,这种“无聊”恰恰是 Go 最重要的魅力之一:极致的可预测性

  • 没有隐式控制流:在 Go 中,代码的执行路径是完全可见的。没有 try-catch 带来的“超级 goto”,没有复杂的继承链和方法重载,也没有操作符重载带来的“魔法”。你看到的,就是即将发生的。
  • 错误处理的确定性:if err != nil 虽然繁琐,但它强制开发者在每一个可能出错的地方,都必须做出明确的处理。这使得错误处理路径成为代码中清晰、可见的一部分,而不是一个随时可能从天而降的“异常”。

让我们看一个简单的文件读取例子。在某些语言中,它可能看起来很简洁:

# Python 示例
try:
    content = read_file("some_file.txt")
    process(content)
except FileNotFoundError:
    handle_not_found()
except PermissionError:
    handle_permission_denied()

而在Go中,则是我们熟悉的“啰嗦”模式:

// Go 示例
content, err := readFile("some_file.txt")
if err != nil {
    if os.IsNotExist(err) {
        handleNotFound()
    } else if os.IsPermission(err) {
        handlePermissionDenied()
    } else {
        // Handle other errors
    }
    return
}
process(content)

Python的 try-catch 看起来更“优雅”,但控制流发生了隐式的跳转。而Go的方式,虽然代码行数更多,但错误的处理逻辑是线性的、局部的、无法被忽略的。对于构建大型、可维护的系统而言,这种看似“无聊”的显式和直白,是一种极其宝贵的资产。它降低了代码的认知负荷,让任何一位团队成员都能快速理解并信任一段代码的行为。这是一种褪去华丽外表后,回归工程本质的、成熟的美。

“简单”的背后,是组合的无限可能

Singh 接着说,Go 是“愚蠢地简单,直到它突然变得复杂”。这份“突然的复杂”,并非源于语言本身的复杂性,而是源于 Go 提供的那些极其简单的原语,在组合之后所爆发出的巨大能量

这其中最具代表性的,就是 Go 的并发模型。

当 Singh 感叹自己“像写诗一样写着 goroutine”时,他所体验到的,正是 Go 并发设计的核心魅力。Go 没有提供复杂的线程库或 async/await 语法,它只给了你两个最基础的构建块:

  • go 关键字:一种极其廉价的、启动并发任务的方式。
  • channel:一种用于在并发任务之间安全通信和同步的管道。

正是这两个看似“简陋”的原语,让开发者能够像拼接乐高积木一样,以一种直观、优雅的方式,构建出极其复杂的并发模式。从“扇入扇出”(Fan-in/Fan-out) 到“流水线”(Pipelines),再到优雅的超时和取消控制。


Go的并发原语,如积木般可被组合成强大的并发模式

这份隐藏在简单之下的兴奋感,正是 Go “简单却不简陋,无聊却又令人兴奋”的最佳注脚。

“中间态”的定位,是务实主义的最终胜利

最后,让我们回到 Singh 那段最富哲学意味的描述:

“从未有过前后之分,而是介于两者之间。”
(Never been before and after but somehow in the middle.)

Go 在现代编程语言光谱中,确实处于一个独特的“中间态”。它是一种务实的、为解决问题而生的工程语言:

  • 它不像 C 那样强迫你手动管理内存,但通过指针让你保留了对内存布局的基本理解。
  • 它不像 Python 那样高度动态,但通过其简洁的语法和强大的工具链,提供了极高的开发效率。
  • 它不像 Rust 那样追求编译期的极致安全,但通过 GC 和明确的错误处理,在安全性和开发速度之间取得了绝佳的平衡。

对于许多从 Rust 这样的语言过来的开发者,初期的体验很可能是一场“战斗”。你会怀念那些强大的抽象工具。然而,当你跨越了这段“排异反应”期,开始真正用 Go 的方式去思考和构建时,你便会与这门语言达成“和解”。

小结

长期用过Go语言进行开发的朋友也许都会发现,Go 并没有试图成为一门在理论上最完美、功能上最丰富的语言。它的所有设计,都服务于一个核心目标:让一个由普通工程师组成的团队,能够以一种可持续的方式,高效地构建出健壮、可维护的大型软件。

在这个热衷于创造复杂性、追逐下一个“银弹”的技术时代,Go的这份“无聊”与“克制”,或许才是一种最稀缺、也最值得我们工程师珍视的品质。

这,或许就是这门“无聊”语言,最深刻、也最持久的魅力。

资料链接:https://x.com/0xlelouch_/status/1990139566150566379


聊聊你的“真香”时刻

Singh 的经历让我们看到了技术选择的另一面。作为 Gopher,你在使用 Go 的过程中,是否有过从“嫌弃它的繁琐”到“享受它的确定性”的心理转变?或者,你认为 Go 的哪一个“无聊”特性,反而在实际工程中救了你的命?

欢迎在评论区分享你的故事和感悟!

如果这篇文章让你对 Go 的设计哲学有了新的理解,别忘了点个【赞】和【在看】,分享给更多在技术选型中迷茫的朋友!


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

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

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


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

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

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

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

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


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

MinIO 开源版突发“安乐死”:维护模式开启,社区愤怒,你的数据还安全吗?

本文永久链接 – https://tonybai.com/2025/12/04/minio-enter-maintenance-mode

大家好,我是Tony Bai。

“这个项目目前处于维护状态,不接受新的更改。”

近日,GitHub 上拥有近 60k Star、Go 语言生态中最著名的开源对象存储项目——MinIO,悄然修改了其 README。这一行看似平淡的声明,标志着 MinIO 开源版实际上已经被宣判了“死刑”。

曾经,MinIO 是自建 S3 兼容存储的首选,是开源界的宠儿。如今,它转身拥抱了企业级市场和 AI 浪潮,留下了一脸错愕的社区用户和无数依赖它的开源项目。这究竟是一场无奈的求生,还是一次蓄谋已久的“收割”?

突如其来的“维护模式”

MinIO 官方在没有任何预警的情况下,将其开源仓库置于“维护模式”。这意味着:

  • 功能冻结:不再接受任何新功能或改进。
  • 社区关门:不再接受 Pull Request,现有的 Issue 和 PR 也不会被积极审查。
  • 安全补丁随缘:关键的安全修复“可能”会根据具体情况进行评估,不再有保证。

官方建议很明确:“对于企业支持和积极维护的版本,请参阅MinIO AIStor。”,而AIStor则是MinIO的企业版对象存储产品。

这一举动在 Hacker News 上引发了轩然大波。用户感到被背叛,一位评论者愤怒地写道:“太恶心了。构建一个产品,通过开源获得动力,等你做完了就完全抛弃它。我为曾经推广这个项目感到羞耻。”

为何“背叛”?—— 商业化的必然与 AI 的诱惑

MinIO 的转向并非无迹可寻。从更换为更严格的 AGPL 协议,到此次事实上的闭源,其背后的逻辑清晰而冷酷:

开源无法变现的困境

MinIO 作为一个高性能、单二进制文件的存储服务,太容易“被集成”了。云厂商、集成商可以轻松地将其打包进自己的产品中获利,而 MinIO 公司却难以从中分一杯羹。AGPL 协议虽然意在限制云厂商的“白嫖”,但也未能从根本上解决其商业化难题。

AI 浪潮的巨大诱惑

MinIO 的新产品名为 AIStor。这不仅仅是一个改名,更是一次战略转型。在 AI 时代,数据存储是基础设施的核心。MinIO 试图通过重新包装,将自己定位为 AI 基础设施的关键组件,从而向更有付费能力的企业客户(尤其是 AI 公司)靠拢。

正如一位 HN 用户指出的:“他们在上一轮融资中估值 10 亿美元,要想成功退出,必须有深口袋的买家(如 Nvidia, Dell 等)。现在的开源版本只会拖累他们的财报。”

社区的反击与法律迷局

MinIO 的做法也引发了法律层面的争议。

  • 贡献者的权利:MinIO 曾要求贡献者签署 CLA(贡献者许可协议)。这意味着 MinIO 公司拥有代码的版权,他们确实有权改变许可证或停止开源。
  • AGPL 的约束:但对于那些没有签署 CLA 的早期贡献者,或者包含在代码库中的第三方 AGPL 代码,MinIO 是否有权单方面“私有化”?这是一个复杂的法律问题。

更有趣的是,MinIO 过去曾因 AGPL 许可问题积极“维权”,甚至公开指责其他公司违反协议。如今,它自己却试图摆脱开源的束缚,这种双重标准让社区感到讽刺。

历史的镜像 —— Redis 与 Valkey 的启示

MinIO 的剧变,让人不由得想起了 2024 年初震动开源界的另一场“地震”——Redis 修改开源协议事件

当时,Redis Inc. 宣布不再遵循开源定义,转而采用限制性更强的 SSPL 协议。这一举动激怒了整个社区和云厂商,Linux 基金会迅速集结了 AWS、Google、Oracle 等巨头,基于 Redis 旧版本 fork 出了 Valkey。如今,Valkey 已经展现出取代 Redis 的蓬勃生命力。

MinIO 与 Redis 的异同:

  • 相同点:两者都面临“云厂商困境”。AWS 直接拿 Redis 做 ElastiCache,拿 MinIO 做兼容 S3 的服务,却无需向原厂付费。原厂为了生存,不得不通过协议(AGPL/SSPL)或停止维护来“筑墙”。
  • 不同点:Redis 选择了“掀桌子”(改协议),引发了激烈的对抗和即时的 Fork(Valkey);而 MinIO 选择了“冷处理”(维护模式),这更像是一种温水煮青蛙式的告别。

MinIO 会迎来它的“Valkey 时刻”吗?

目前来看,难。对象存储的复杂度和维护成本远高于内存缓存,且市场上已经存在成熟的替代品(如 SeaweedFS, Ceph, Garage)。MinIO 社区或许不会像 Redis 那样迅速集结出一个统一的 Fork,而是会走向分裂和迁徙

对于开发者而言,Redis 和 MinIO 的连续“暴雷”是一个明确的信号:在基础设施选型时,除了关注技术指标,更要评估其背后的治理模式。由单一商业公司绝对控制的“开源”项目,始终悬着一把达摩克利斯之剑。

自救指南 —— 寻找 MinIO 的替代品

对于现有的 MinIO 用户来说,现在是时候寻找备胎了。社区推荐了几个值得关注的替代方案:

SeaweedFS (Go)

  • 特点:基于 Haystack 论文实现,擅长处理海量小文件,自带 File 和 S3 接口。
  • 适用场景:需要高性能小文件存储的场景。
  • 评价:功能丰富,甚至有点“过度”,但性能强悍。

Ceph (C++)

  • 特点:存储界的瑞士军刀,功能极其强大,但也极其复杂。
  • 适用场景:大规模、生产级、需要块存储和文件存储的场景。
  • 评价:如果你有运维团队,Ceph 是永远不会错的选择。

Versity Gateway (Go)

  • 特点:基于文件的 S3 网关,可以在开发测试环境作为 MinIO 的直接替代品,后端直接对接文件系统。

RustFS (Rust)

  • 特点:野心勃勃的新晋选手,试图在性能和易用性上直接对标甚至超越 MinIO。
  • 适用场景:极客尝鲜、非生产环境的测试与评估。
  • 评价:社区评价两极分化。一方面,它展现了强大的潜力;另一方面,用户反馈其目前稳定性欠佳,且项目要求签署 CLA(贡献者许可协议),这让不少刚被 MinIO 伤过心的开发者担心它未来会重演“养肥再杀”的剧本。“潜力巨大,但需谨慎观望。”

Garage (Rust)

  • 特点:轻量级、自包含、专注于在异构硬件和地理分布的网络上运行。
  • 适用场景:自托管、家庭实验室、中小规模集群。
  • 评价:“非常稳固,简单可靠,没有风险投资背景。”

小结:开源的尽头是商业,还是背叛?

MinIO 的故事,是开源软件商业化困境的又一个注脚。它提醒我们:

  • 没有免费的午餐:由 VC 支持的开源项目,最终都要面临盈利的压力。当增长遇到瓶颈,社区往往是被牺牲的第一个对象。
  • 选择开源项目需谨慎:除了代码质量,项目的治理结构、CLA 协议、背后的商业模式,都是选型时必须考虑的风险因素。

MinIO 虽已“离去”,但开源精神不死。也许下一个更好的 MinIO,正在某个 GitHub 的角落里悄然生长。

资料链接:https://news.ycombinator.com/item?id=46136023


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

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

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


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

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

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

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

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


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

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