OpenAI Codex 中文文档(4.14更新)
联系我
官方文档

使用 AGENTS.md 编写自定义说明

为你的项目向 Codex 提供额外指令和上下文

Codex 会在开始任何工作前读取 AGENTS.md 文件。通过把全局指导和项目级覆盖层叠起来,你就能在每次打开任意仓库时,都从一致的工作预期开始。

Codex 如何发现这些指导

Codex 启动时会整理出一条本次运行要使用的指令链。这个过程每次运行都会重新执行;在终端界面(TUI)中,通常就是每次新建会话时重新构建。查找顺序如下:

  1. 全局层: 先检查 Codex 主目录(默认是 ~/.codex,也可以通过 CODEX_HOME 指定)。如果存在 AGENTS.override.md,就使用它;否则再读取 AGENTS.md。这一层只会采用找到的第一个非空文件。
  2. 项目层: 然后从项目根目录(通常是 Git 根目录)一路检查到当前工作目录。如果没有找到项目根,就只检查当前目录。沿途每一级目录都会按 AGENTS.override.mdAGENTS.mdproject_doc_fallback_filenames 中定义的备用文件名这一顺序查找;每个目录最多只会纳入一个文件。
  3. 合并顺序: 最后,Codex 会按“从根到当前目录”的顺序把这些文件拼接起来。越靠近当前目录的文件越靠后,因此会覆盖前面更通用的说明。

空文件会被跳过。合并后的总大小一旦达到 project_doc_max_bytes 设定的上限(默认 32 KiB),Codex 就不会再继续加入更多文件。关于这些参数,参见 项目指令发现。如果触到上限,可以调大限制,或把指令拆到更深一层的目录中。

创建全局指导

在 Codex 主目录中创建持久默认值,这样每个仓库都会继承你的工作约定。

  1. 确保目录存在:

    mkdir -p ~/.codex
  2. 创建 ~/.codex/AGENTS.md,写入可复用偏好:

    # ~/.codex/AGENTS.md
    
    ## 工作约定
    
    - 修改 JavaScript 文件后,始终运行 `npm test`
    - 安装依赖时优先使用 `pnpm`
    - 添加新的生产依赖前先征求确认。
  3. 在任意目录运行 Codex,确认它已加载该文件:

    codex --ask-for-approval never "Summarize the current instructions."

    预期结果:Codex 会在给出工作建议前,先引用 ~/.codex/AGENTS.md 中的条目。

当你需要临时性的全局覆盖,而又不想删除基础文件时,可以使用 ~/.codex/AGENTS.override.md。删除这个覆盖文件后,就会恢复共享指导。

分层组织项目说明

仓库级文件可以让 Codex 感知项目规范,同时继续继承你的全局默认值。

  1. 在仓库根目录添加一个 AGENTS.md,写入基础约定:

    # AGENTS.md
    
    ## 仓库通用约定
    
    - 在创建 pull request 前运行 `npm run lint`
    - 修改行为时,在 `docs/` 中记录对外公共工具的变化。
  2. 当某些团队需要不同规则时,在嵌套目录中添加覆盖文件。例如在 services/payments/ 下创建 AGENTS.override.md

    # services/payments/AGENTS.override.md
    
    ## payments 服务规则
    
    - 使用 `make test-payments`,不要使用 `npm test`
    - 轮换 API key 前,必须先通知安全频道。
  3. payments 目录启动 Codex:

    codex --cd services/payments --ask-for-approval never "List the instruction sources you loaded."

    预期结果:Codex 会先报告全局文件,再报告仓库根目录 AGENTS.md,最后报告 payments 目录下的覆盖文件。

Codex 的搜索会在到达当前目录时停止,因此应把覆盖文件尽量放在靠近专门化工作的地方。

添加全局文件和 payments 专属覆盖文件后,仓库结构示例如下:

  • AGENTS.md 仓库通用约定
  • services/
    • payments/
      • AGENTS.md 因为存在覆盖文件,所以会被忽略
      • AGENTS.override.md payments 服务规则
      • README.md
    • search/

自定义备用文件名

如果你的仓库已经在使用其他文件名(例如 TEAM_GUIDE.md),你可以把它加入备用列表,让 Codex 也把它当作说明文件。

  1. 编辑你的 Codex 配置:

    # ~/.codex/config.toml
    project_doc_fallback_filenames = ["TEAM_GUIDE.md", ".agents.md"]
    project_doc_max_bytes = 65536
  2. 重启 Codex,或者运行一条新的命令,让更新后的配置被加载。

这样一来,Codex 就会按以下顺序检查每个目录:AGENTS.override.mdAGENTS.mdTEAM_GUIDE.md.agents.md。不在这个列表中的文件名不会参与说明文件发现。更大的字节上限则允许合并更多指导内容后再截断。

设置好备用列表后,Codex 会把这些替代文件也视作说明文件:

  • TEAM_GUIDE.md 通过备用列表发现
  • .agents.md 根目录中的备用文件
  • support/
    • AGENTS.override.md 覆盖备用文件中的指导
    • playbooks/

如果你希望使用不同配置档,例如某个项目专用的自动化账号,可以设置 CODEX_HOME 环境变量:

CODEX_HOME=$(pwd)/.codex codex exec "List active instruction sources"

预期结果:输出会列出相对于自定义 .codex 目录的文件路径。

验证你的设置

  • 在仓库根目录运行 codex --ask-for-approval never "Summarize the current instructions."。正常情况下,Codex 会按优先级顺序复述全局和项目级指导。
  • 使用 codex --cd subdir --ask-for-approval never "Show which instruction files are active.",确认更深层目录中的覆盖文件是否真正替换了更上层规则。
  • 如果你开启了会话日志,可以检查 ~/.codex/log/codex-tui.log,或最新的 session-*.jsonl,核对 Codex 实际加载了哪些说明文件。
  • 如果你感觉说明内容仍然是旧的,直接在目标目录重启 Codex。Codex 每次运行都会重新构建指令链,不需要手动清缓存。

排查发现问题

  • 什么都没有加载: 确认你当前位于预期仓库中,并检查 codex status 返回的工作区根目录是否正确。同时确保说明文件不是空文件,因为空文件会被忽略。
  • 出现了错误指导: 检查目录树更上层或 Codex 主目录中是否存在 AGENTS.override.md。如果有,它会优先于普通 AGENTS.md 生效。
  • Codex 忽略了备用文件名: 确认这些文件名已经无拼写错误地写进 project_doc_fallback_filenames,然后重启 Codex 让新配置生效。
  • 指令被截断: 检查 project_doc_max_bytes,必要时调大上限,或把大文件拆到更深层目录中。
  • 配置档混淆: 运行 echo $CODEX_HOME。如果它不是默认值,说明 Codex 正在读取另一个主目录中的全局说明。

下一步


来源:https://developers.openai.com/codex/guides/agents-md