TL;DR

YC CEO Garry Tan 开源的 gstack 和 Anthropic 官方的 Skills 看似代表 AI 编程的两种哲学(流程治理 vs 能力扩展),但深入分析发现:gstack 本身就是基于 Skills 机制实现的预置流程包。两者的关系不是对立,而是层次——Skills 是底层能力扩展机制,gstack 是基于该机制构建的开发流程工具。对于已经在使用 Claude Code 的开发者,建议:用 gstack 快速建立流程,用 Skills 扩展定制能力。

⚠️ 读者定位:本文假设你已经了解 Claude Code 的基本使用方式。如果你还没用过 Claude Code,建议先阅读 Claude Code 官方文档


📋 本文结构

  1. 背景:两个人,一个机制
  2. gstack:预置的开发流程
  3. Skills:底层的能力扩展机制
  4. 核心发现:gstack 是 Skills 的一种实现
  5. 使用场景:如何选择
  6. 组合使用:完整的开发工作流
  7. 未来趋势:技能市场的兴起

背景:两个人,一个机制

Garry Tan 与 gstack

Garry Tan(YC CEO)在 2025 年底开源了 gstack——一套基于 Claude Code 的开发流程工具。

📌 关于”60万行代码”:Tan 声称过去 60 天写了 60 万行”生产代码”。这个数据存在争议(如何定义”写”?是否包含生成代码?),本文不将其作为论证依据。gstack 的价值在于其流程设计,而非产量数据。

Thariq 与 Skills

Thariq Nazeer(Anthropic 工程师,Claude Code 核心开发者)在 X 上分享了 Anthropic 内部使用 Skills 的经验。

他的核心观察:“Skill 不只是 Markdown 文件,而是包含脚本、资产、数据的完整文件夹。”

一个关键事实

初看之下,gstack 和 Skills 似乎是两个独立的项目,代表不同的方法论。但当我们检查 gstack 的代码结构时,发现了一个重要事实:

gstack 本身就是用 Skills 机制实现的。

这个发现改变了整篇文章的 premise——我们不是在面对”两种哲学”,而是在面对”一个机制的不同应用层次”。


gstack:预置的开发流程

核心理念

gstack 将 Claude Code 变成一个虚拟工程团队,通过 15 个 “/命令” 把开发流程拆成 7 个阶段:

Think → Plan → Build → Review → Test → Ship → Reflect
阶段 命令 角色定位 核心功能
Think /office-hours YC Office Hours 6个强制问题重新定义产品
Think /plan-ceo-review CEO/创始人 10节审查重新思考问题
Plan /plan-eng-review 工程经理 ASCII 图、数据流、边界情况
Plan /plan-design-review 高级设计师 0-10 分评级每个设计维度
Review /review 高级工程师 发现 CI 通过但生产爆炸的 Bug
Test /qa QA 主管 真实浏览器点击测试、修复 Bug
Ship /ship 发布工程师 同步、测试、审计、推送、开 PR

关键特性

1. 流程连贯性

/office-hours 写的文档 → /plan-ceo-review 读取
/plan-eng-review 写的测试计划 → /qa 读取
/review 发现的 Bug → /ship 验证修复

2. 安全护栏

  • /careful:破坏性命令前警告
  • /freeze:限制编辑到单个目录
  • /guard:/careful + /freeze

3. 浏览器能力

  • /browse:真实 Chromium 浏览器
  • /setup-browser-cookies:导入真实浏览器 cookies

Skills:底层的能力扩展机制

核心理念

Skills 是 Claude Code 的能力扩展机制。一个 Skill 是一个文件夹,包含:

  • 脚本(scripts/)
  • 资产(assets/)
  • 数据(data/)
  • 配置(config.json)
  • Hooks(动态拦截)

9 种 Skill 类型

类型 功能定位 典型示例
Library & API Reference 库和 API 参考 billing-lib、内部平台 CLI
Product Verification 产品验证测试 signup-flow-driver、checkout-verifier
Data Fetching & Analysis 数据获取与分析 funnel-query、grafana
Business Process Automation 业务流程自动化 standup-post、create-ticket
Code Scaffolding 代码脚手架 new-service、new-migration
Code Quality & Review 代码质量审查 adversarial-review、code-style
CI/CD & Deployment CI/CD 与部署 babysit-pr、deploy-service
Runbooks 运维手册 service-debugging、oncall-runner
Infrastructure Operations 基础设施操作 resource-orphans、cost-investigation

触发机制

与 gstack 的显式命令不同,Skills 通常通过自然语言描述触发:

用户:帮我部署 api 服务到 staging
Claude:(识别到 "部署" 意图)
      ↓
      加载 deploy-service Skill
      ↓
      执行部署流程

关键特性

1. 渐进式披露

SKILL.md(概述)
    ↓
references/api.md(详细 API)
references/examples.md(示例)
scripts/utils.py(工具函数)

2. Hooks 机制

  • PreToolUse:工具使用前拦截
  • /careful:阻止 rm -rf、DROP TABLE
  • /freeze:限制编辑范围

核心发现:gstack 是 Skills 的一种实现

证据:gstack 的文件结构

当我们检查 gstack 的安装目录,发现它完全符合 Skills 的规范:

~/.claude/skills/gstack/
├── SKILL.md              # Skill 主文档
├── config.json           # Skill 配置
├── skills/               # 15 个子 Skill
│   ├── office-hours/
│   │   ├── SKILL.md      # 该命令的描述
│   │   └── scripts/      # 支持脚本
│   ├── review/
│   ├── qa/
│   └── ...
└── scripts/              # 共享脚本
    ├── utils.sh
    └── constants.py

这意味着什么

gstack 不是与 Skills 竞争的工具,而是基于 Skills 构建的预置流程包。

两者的关系是层次关系,不是平行关系:

Skills(底层机制)
    ↓
gstack(基于 Skills 的应用层实现)
    ↓
15 个开发流程命令

类比理解

类比 关系说明
macOS 与应用程序 Skills 是 macOS,gstack 是一个特定的应用程序
编程语言与框架 Skills 是语言特性,gstack 是基于该特性的框架
API 与客户端 Skills 是服务端 API,gstack 是一个特定的客户端实现

对开发者的启示

既然 gstack 是 Skills 的一种实现,这意味着:

  1. 你可以用相同的方式构建自己的流程
    • 学习 gstack 的结构
    • 根据自己的需求定制
    • 不需要等待官方支持
  2. gstack 和自定义 Skills 可以共存
    • 用 gstack 作为基础流程
    • 用自定义 Skills 扩展特定能力
  3. gstack 的演进依赖 Skills 机制
    • gstack 的新功能需要 Skills 机制支持
    • 理解 Skills 有助于更好地使用 gstack

使用场景:如何选择

直接结论

场景 推荐选择 理由
个人快速开发 gstack + 少量自定义 Skills 快速建立流程,无需从零设计
团队标准化 自定义 Skills 为主 根据团队需求定制,避免 gstack 的 YC 偏见
特定领域工具 自定义 Skills gstack 专注通用开发流程,特定工具需要自己构建
流程改造 参考 gstack 结构自建 学习其设计模式,但根据自己的工作流调整

什么情况下不用 gstack

  1. 非 YC 风格的开发流程
    • gstack 内置了强烈的 YC 创业方法论(快速迭代、快速发布)
    • 如果你的团队有不同的节奏,直接套用可能适得其反
  2. 已有成熟的开发流程
    • 如果团队已经有标准化的流程,迁移到 gstack 的成本可能大于收益
    • 更好的选择:把现有流程封装成自定义 Skills
  3. 需要深度定制的场景
    • gstack 是预置的,修改需要 fork
    • 如果需求差异很大,自建可能更简单

组合使用:完整的开发工作流

实际使用示例

假设你要构建一个新功能,完整的工作流可能是:

Step 1: 流程启动(gstack)

/office-hours
→ 重新定义问题:"你想构建 X,但实际上你需要 Y"

Step 2: 架构设计(gstack)

/plan-eng-review
→ 输出数据流图、API 设计、测试策略

Step 3: 代码生成(Claude Code 原生)

  • 基于架构设计生成代码

Step 4: 质量检查(gstack + 自定义 Skill)

/review                    # gstack 命令:通用代码审查
→ 发现边界情况

# 同时加载自定义 Skill:
# - internal-security-check Skill(检查内部安全规范)
# - performance-budget Skill(检查性能指标)

Step 5: 测试验证(gstack)

/qa https://staging.myapp.com
→ 打开真实浏览器,发现并修复 Bug

Step 6: 发布(gstack + 自定义 Skill)

/ship                      # gstack 命令:标准发布流程

# 同时触发自定义 Skill:
# - deploy-to-k8s Skill(部署到内部 K8s 集群)
# - notify-slack Skill(发送发布通知)

架构图

用户输入
    ↓
意图识别(Claude Code)
    ↓
┌─────────────────────────────────────────┐
│ 决策:使用 gstack 命令还是加载 Skill?      │
├─────────────────────────────────────────┤
│ gstack 命令(如 /review)                 │
│     ↓                                   │
│ 预置流程执行(用 Skill 机制实现)          │
├─────────────────────────────────────────┤
│ 自定义 Skill(如 deploy-service)          │
│     ↓                                   │
│ 能力扩展执行                            │
└─────────────────────────────────────────┘
    ↓
结果输出

未来趋势:技能市场的兴起

基于证据的判断

根据 Anthropic 的产品动向和业界趋势,融合走向可能性更大

证据 解读
Claude Code 官方文档增加 Skills 章节 Skills 正在从内部实践变为官方支持的功能
Skills 增加流程编排相关特性 官方正在填补 gstack 覆盖的流程治理能力
gstack 依赖 Skills 机制 两者技术上已经耦合,分化需要技术隔离

判断:未来不太可能是”gstack vs Skills”的二选一,而是 Skills 成为底层标准,gstack 和其他流程工具成为上层应用。

预测:技能市场的形成

类似于 VS Code 的插件市场,我们可能会看到:

Claude Code Skills 市场
    ├── 流程类(gstack 及变体)
    ├── 工具类(部署、测试、监控)
    ├── 领域类(前端、后端、AI、数据)
    └── 团队私有(企业内部 Skills)

给开发者的具体建议

现在应该做什么

  1. 如果你刚开始使用 Claude Code
    • 先安装 gstack,快速建立开发流程
    • 在使用过程中记录哪些环节需要定制
    • 逐步添加自定义 Skills
  2. 如果你已经在使用 gstack
    • 学习其 Skills 结构(~/.claude/skills/gstack/
    • 尝试修改或扩展其中的某个命令
    • 考虑把团队特定的流程封装成 Skills
  3. 如果你是平台工程团队
    • 建立内部 Skills 仓库
    • 封装内部的工具、库、流程
    • 参考 gstack 设计团队特定的流程工具
  4. 如果你是技能开发者
    • 关注 Skills 机制的演进
    • 考虑开源你的 Skills(类似于开源 VS Code 插件)
    • 参与可能的官方 Skills 市场

结论

核心洞察的修正

本文开头的 TL;DR 说”两种哲学”,但经过分析,更准确的说法是:

Skills 是 Claude Code 的能力扩展机制,gstack 是基于该机制构建的开发流程工具。

两者的关系不是”流程 vs 能力”的对立,而是”机制 vs 应用”的层次。

关键结论

问题 答案
gstack 和 Skills 是竞争关系吗? 不是。gstack 是用 Skills 实现的
我应该用哪个? 两者都用——gstack 作为起点,Skills 用于扩展
可以自建类似 gstack 的工具吗? 可以。学习 gstack 的 Skills 结构,按需定制
未来会如何演进? Skills 成为底层标准,上层出现多样化的流程工具

比喻修正

原比喻(需要修正):

  • ❌ “gstack 是乐谱,Skills 是乐器”(暗示两者平行)

更准确的理解:

  • ✅ “Skills 是乐器制造技术,gstack 是用该技术制造的一把特定乐器”
  • ✅ “Skills 是编程语言特性,gstack 是用该特性编写的框架”

最终建议

  1. 从 gstack 开始:如果你还没有成熟的 Claude Code 工作流,gstack 是一个很好的起点。

  2. 理解 Skills 机制:学习 gstack 的 Skills 结构,这会让你明白如何扩展和定制。

  3. 逐步定制:根据你的实际需求,添加自定义 Skills,修改或替换 gstack 的某些命令。

  4. 关注生态演进:Skills 机制还在发展,未来可能出现官方市场和更多工具。

这才是 AI-Native 软件工程的完整图景——不是选择一套固定的工具,而是理解底层机制,构建适合自己的工作流。


参考与延伸阅读


本文基于 gstack 开源代码和 Anthropic 官方文档深度分析。核心发现(gstack 是 Skills 的一种实现)可通过检查 ~/.claude/skills/gstack/ 目录结构验证。

发布于 postcodeengineering.com