标签 Makefile 下的文章

Bash 虽好,但我选 Go:如何用 10 倍代码换来 100 倍的维护性?

本文永久链接 – https://tonybai.com/2025/12/24/bash-vs-go-10x-code-100x-maintainability

大家好,我是Tony Bai。

“Bash 是一种很棒的胶水语言,但 Go 是更好的胶水。”

在日常开发中,我们经常会写一些 Bash 脚本来处理本地环境配置、启动 Docker 容器、同步密钥等琐碎任务。起初,它们只是几行简单的命令;但随着时间推移,它们逐渐膨胀成包含数百行 jq、sed、awk 的怪物,充斥着针对 macOS 和 Linux 的条件分支,以及“千万别动这行代码”的注释。

近日,一位开发者分享了他用 Go 重写这些 Bash 脚本的经历,引发了一场Go社区的关于工程可维护性“胶水代码”治理的深度探讨。

在本文中,我们将跟随这位开发者的视角,深入剖析这次从脚本到工程的“降熵”之旅,并探讨在 AI 辅助编程日益普及的今天,这一选择背后的新逻辑。

Bash 脚本的“熵增”之路

许多团队的本地开发环境脚本,往往始于一个简单的需求:从 AWS SSM 或 Vault 拉取密钥,生成 .env 文件,然后启动服务。

最初的 Bash 脚本可能只有 10 行。但随着需求增加,它变成了这样:

  • 工具链依赖地狱:脚本依赖特定版本的 sed、grep 或 jq。一旦某个同事更新了系统工具,脚本就挂了。
  • 跨平台噩梦:sed 在 macOS 和 Linux 上的行为不一致,导致脚本中充斥着 if [[ "$OS" == "darwin" ]] 这样的分支。
  • 调试困难:当脚本出错时,你很难知道是哪一行管道(pipe)出了问题,也没有类型检查来帮你发现潜在错误。

正如评论区一位开发者所言:“Bash 脚本就像是一堆没有明确所有权的‘杂物’。每个人都在上面打补丁,直到它变成一个没人敢碰的定时炸弹。”

Go 作为“强力胶水”的优势

原作者将这堆复杂的 Bash 逻辑重构为一个名为 envmap 的小型 Go CLI 工具。虽然代码行数可能增加了(Go 确实比 Bash 繁琐),但他收获了工程质量的质变

结构化配置与类型安全

不再有脆弱的字符串解析。配置被定义为强类型的 struct,编译器会帮你检查拼写错误和类型不匹配。

// Bash: 祈祷这个字符串解析是对的...
// Go: 编译器保证它是对的
type Config struct {
    Env      string json:"env"
    Region   string json:"region"
    UseVault bool   json:"use_vault"
}

接口抽象与可测试性

原作者定义了一个 Provider 接口来抽象不同的密钥后端(AWS SSM, Vault, 本地文件)。这不仅让代码结构清晰,更重要的是,它变得可测试了。你可以轻松编写单元测试来验证逻辑,而无需真的连接到 AWS。

type Provider interface {
    Get(ctx context.Context, key string) (string, error)
    // ...
}

跨平台的一致性

Go 编译出的静态二进制文件,消除了“它在我的机器上能跑”的问题。无论同事使用 macOS、Linux 还是 Windows,他们运行的都是相同的逻辑,不再受系统自带 Shell 工具版本的影响。

社区的思辨——“杀鸡用牛刀”吗?

这场重构也引发了激烈的讨论。有开发者质疑:用 Go 写脚本是不是太重了?Python 或 TypeScript 岂不是更好的替代品?甚至,为什么不直接用 Makefile?

反方观点:复杂度的转移

  • “代码更多了”:Go 的 verbose(繁琐)是公认的。简单的 cp a b 在 Go 中需要写不少代码。
  • “编译步骤”:虽然 go run很快,但毕竟多了一个编译环节。

正方观点:维护性的胜利

  • “长期收益”:一位开发者分享了他将 40k 行 Bash/Perl 脚本重构为 10k 行 Go 代码的经历。虽然初期投入大,但获得了测试覆盖文档化零依赖部署的巨大收益。
  • “显式契约”:Bash 脚本之间往往通过不稳定的文本流(stdout/stdin)通信,极其脆弱。而 Go 代码之间通过明确的接口和模块调用通信,更加稳健。

正如一位评论者总结的:“如果你只是写一个 10 行的脚本,Bash 是完美的。但如果你的脚本开始需要处理复杂的逻辑、状态和错误,那么它就不再是一个脚本,而是一个程序。既然是程序,就应该用编写程序的语言(如 Go)来写。”

AI 时代的变量——“繁琐”不再是借口

在过去,阻碍开发者用 Go 替代 Bash 的最大阻力往往是编写效率。写一个几十行的 Go 程序来替换一行 sed 命令,听起来确实不仅“繁琐”,而且“低效”。

然而,在 AI 辅助编程(如 Copilot, Cursor, Claude Code等)普及的今天,这个天平正在发生倾斜。

AI 为 Go 支付了“样板税”

Go 语言的 verbose(繁琐)特性——显式的错误处理、结构体定义、库的引入——曾经是手写代码的负担。但在 AI 时代,这些标准化的样板代码恰恰是 LLM(大语言模型)最擅长生成的

你只需要告诉 AI:“写一个 CLI,读取环境变量,请求 AWS SSM,如果有错误就打印红色日志。” AI 能瞬间生成 80% 的 Go 代码骨架。开发者只需专注于核心逻辑的微调。

编译器是 AI 最好的“质检员”

用 AI 生成 Bash 脚本是一场赌博。LLM 可能会编造出不存在的 awk 参数,或者写出在某些 Shell 下不兼容的语法,而这些错误往往要在运行时才能发现(甚至引发灾难性的 rm -rf)。

相比之下,用 AI 生成 Go 代码具有天然的安全屏障

  • 静态类型检查:如果 AI 幻觉了不存在的方法,编译器会立刻报错,而不是等到运行时崩溃。
  • 确定性:Go 的语法规范极其严格,减少了 AI 生成“虽然能跑但很奇怪”的代码的概率。

正如原作者在回复中所承认的:“我使用了 Cursor 和 Codex,代码的复杂性主要来自业务逻辑,而非语言本身。” 在 AI 的加持下,获得一个类型安全、跨平台、易维护的 Go 二进制文件,其生产效率已经并不输给编写和调试一个脆弱的 Bash 脚本。

小结:从脚本到工程,从手写到 AI 共生

这个案例告诉我们,“胶水代码”也需要工程化治理

当你的 Bash 脚本开始变得让你感到恐惧、难以维护时,不要犹豫,用 Go 重写它吧。虽然你会多写一些 if err != nil,但你换来的是确定性可维护性内心的宁静

特别是在 AI 时代,Go 语言的“繁琐”已被智能助手和编码智能体消解,而它带来的“稳健”却愈发珍贵。Go 也许不是最简洁的胶水,但在 AI 的帮助下,它绝对是性价比最高、最牢固的胶水。

资料链接:https://www.reddit.com/r/golang/comments/1pb7t1q/show_tell_bash_is_great_glue_go_is_better_glue/


你的“胶水”选型

“Bash 还是 Go/Python?”这可能是每个团队都会面临的选择题。在你的工作中,你会为多大规模的脚本选择改用 Go 或 Python 重写?你是否有过被复杂 Bash 脚本“坑”惨的经历?

欢迎在评论区分享你的“血泪史”或“重构心得”! 让我们一起探讨如何让工具代码更优雅。

如果这篇文章给了你重构旧脚本的勇气,别忘了点个【赞】和【在看】,并分享给你的团队!


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

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

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


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

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

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

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

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


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

还在当“上下文搬运工”?我写了一门课,帮你重塑AI开发工作流

本文永久链接 – https://tonybai.com/2025/11/20/ai-native-dev-workflow

大家好,我是Tony Bai。

最近半年,我发现我的开发日常,正被一种新的“工作流摩擦”所困扰。

我猜,你可能也感同身受。

我们在一块屏幕上沉浸于IDE中的Go代码,在另一块屏幕上,则像一个勤奋的“学生”,不断向AI大模型提问。我们从代码库中精心挑选上下文,复制,切换窗口,粘贴,然后带着AI给出的答案,再复制,切换,粘贴回来。

我们成了AI时代的“上下文搬运工”和“提示词调优师”。

IDE插件的出现,让AI离我们更近了一步,它像一个“副驾驶”,能为我们提供实时的建议。但它依然无法真正地“动手”——它不能为你运行一次测试,不能帮你执行一次git commit,更无法理解你那套复杂的Makefile里到底藏着什么玄机。

我们拥抱了AI,却发现自己陷入了一个新的“效率怪圈”。我们与AI的协作,始终是割裂的、被动的、充满摩擦的。

我一直在思考,这真的是AI时代软件开发的终极形态吗?一定有更好的方式。一定有一种方法,能让AI不再是一个外部的“辅助工具”,而是成为我们开发流程中一个原生的、可指挥的、能动手干活的“核心成员”

正是为了系统性地解决这个问题,并把我过去大半年时间的思考、踩坑、实践与沉淀分享出来,我与极客时间合作,倾力打造了一门全新的专栏——AI原生开发工作流实战:重塑新一代软件工程范式

为什么要写这个专栏?

因为我相信,软件开发的范式,正在经历一场深刻的革命。

我们正从“人机协作”的1.0时代,迈向“AI原生”的2.0时代。在这场变革中,开发者的核心价值,将不再仅仅是“写出代码”,而是“设计出能让AI写出高质量代码的工作流”。

而承载这场革命的最佳载体,正是以Claude Code为代表的新一代命令行AI智能体(Command-line Coding Agent)。它们让AI的能力,以前所未有的深度,“活”进了我们最熟悉的开发环境——终端里。

但是,拥有强大的工具,和懂得如何驾驭它,是两回事。

下面是一个AI-开发者集成成熟度模型,你看看你处在哪一层?

我看到的太多开发者,依然在用L1、L2的思维模式,去使用一个为L3、L4工作流设计的强大智能体。这就像开着一辆F1赛车去买菜,不仅没发挥出它的全部性能,还觉得它“不好开”。

这个专栏的目标,就是为你提供那本缺失的“F1赛车驾驶手册”。它不是一本简单的工具说明书,而是一套完整的AI原生开发方法论。我将带你一起,从“第一性原理”出发,重新思考和构建我们在AI时代的软件工程实践。

在这个专栏里,我为你设计了怎样的学习路径?

为了让你能系统性地完成这次思维和技能的升维,我将专栏精心设计为四个层层递进的模块,它就像一张清晰的“升级打怪地图”:

  • 模块一:概念篇 · 建立AI原生世界观
    在这一模块,我们将首先统一认知。你将深入理解什么是“规范驱动开发(Spec-Driven Development)”,这一AI原生开发的核心引擎。我们还会一起扫描整个命令行AI Agent的生态,并最终明确,我们为什么选择Claude Code作为核心的实战载体,以及如何通过接入国产大模型(如智普AI)来解决国内开发者的成本与可用性问题。

  • 模块二:基础篇 · 掌握与AI伙伴协作的通用语言
    我们将从零开始,手把手带你掌握与AI Agent协作的核心交互模型。你将精通上下文的艺术(CLAUDE.md, agents.md, constitution.md),学会如何为AI注入“长期记忆”和项目“宪法”。你还将掌握强大的自定义指令(Slash Commands),开始将你自己的工作流封装为AI可以执行的命令。学完此模块,你将能为任何项目快速定制一套AI‘说明书’,让它秒懂你的代码库。

  • 模块三:进阶篇 · 将Agent锻造成你的专属神器
    这是专栏的“硬核”部分。我们将进入AI Agent的“引擎室”,为你揭示其所有高级特性的工作原理和实战技巧。从安全基石(权限、沙箱、快照回滚),到能力扩展矩阵(Hooks, Skills, Sub-agents, MCP),再到自动化接口(Headless模式),你将学会如何将一个通用AI,彻底“魔改”成一个懂你项目、听你指挥的“专属神器”。学完此模块,你将拥有‘魔改’AI Agent的能力,让它从‘通用模型’变成你的‘专属战友’。

  • 模块四:实战篇 · 在真实项目中重塑工程实践
    这是整个专栏的“毕业大戏”。我们将把前面所有学到的理论和技巧,全部应用到一个从零到一的Go项目构建中。在通过顶层设计建立好你的AI驾驶舱后,你将亲历一个功能,是如何在AI原生工作流的加持下,被一步步地设计(spec.md)、规划(plan.md, tasks.md)、编码(TDD)、审查交付(CI/CD),乃至最终维护与重构的。这将是你把知识转化为能力的最佳演练场。

学完这门课,你将获得什么?

  • 一套前沿的开发方法论: 真正掌握“AI原生开发”与“规范驱动开发”的核心思想,而不仅仅是工具的零散技巧。
  • 一套通用的Coding Agent驾驭技能: 精通上下文注入、自定义工具和技能、自动化编排等核心技巧,无论未来出现什么新的Coding Agent工具,你都能快速上手。
  • 一套可落地的工程实践: 获得AI在需求、设计、TDD、CI/CD、重构等软件工程全流程中的最佳实践和Go语言实战代码。
  • 一次思维模式的升级: 完成从“AI工具使用者”到“AI工作流指挥家”的角色转变,构筑在AI时代的个人核心竞争力。

写在最后:一份“抛砖引玉”的邀请

在策划这门课时,我始终保持着一种敬畏之心。

Claude Code是2025年2月才正式进入大众视野的,至今也不过大半年的时间。整个命令行Coding Agent领域,都还处在一个高速演进、日新月异的“黎明时代”。我们所有人,包括我在内,都还在“摸着石头过河”。

因此,这个专栏的内容会更偏向于基础和入门,我希望通过最详尽的示例,为你直观地展现AI原生工作流的巨大潜力。我为你呈现的,更多是我个人在当前阶段探索出的一种可行的工作流,它未必是放之四海而皆准的“最优解”,更谈不上是“终极银弹”。

我更希望这个专栏,能成为一个“抛砖引玉”的平台。

我把我这块“砖”抛出来,是希望能引出你——每一位身处一线的优秀开发者——那块更宝贵的“玉”。我非常期待你在课程的评论区,分享你的思考、你的工作流、你的“最佳实践”。

我相信,关于AI原生开发的未来,最终的答案,一定不是由我一个人,也不是由任何一个AI公司定义的。它将由我们所有拥抱变革、勇于实践的开发者,共同书写。

让我们一起,成为定义这个新时代开发范式的第一批人。

现在,这门凝结了我大半年心血的课程 AI原生开发工作流实战 已经在极客时间正式上线了!

专栏为图文形式,共22讲。我为你准备了早鸟优惠 ¥59(原价 ¥99),仅限首周。

扫描下方二维码,立即订阅

用一两杯咖啡的钱,投资一次面向未来的思维和技能升级。

如果你想先了解更详细的课程内容,可以点击「这里」查看专栏的详细目录。

期待在课程中,与你相遇,共同精进!

如果本文对你有所帮助,请帮忙点赞、推荐和转发!


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

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