Claude Code
将编码任务委托给 Claude Code CLI(功能开发、PR)。
技能元数据
| 来源 | 内置(默认安装) |
| 路径 | skills/autonomous-ai-agents/claude-code |
| 版本 | 2.2.0 |
| 作者 | Hermes Agent + Teknium |
| 许可证 | MIT |
| 平台 | linux, macos, windows |
| 标签 | Coding-Agent, Claude, Anthropic, Code-Review, Refactoring, PTY, Automation |
| 相关技能 | codex, hermes-agent, opencode |
以下是Hermes在此技能触发时加载的完整技能定义。这是智能体在技能激活时看到的指令。
Claude Code — Hermes 编排指南
通过Hermes终端将编码任务委派给Claude Code(Anthropic的自主编码智能体CLI)。Claude Code v2.x可以读取文件、编写代码、运行shell命令、生成子智能体并自主管理工作流。
前提条件
- 安装:
npm install -g @anthropic-ai/claude-code - 认证: 运行
claude一次进行登录(Pro/Max版本使用浏览器OAuth,或设置ANTHROPIC_API_KEY) - 控制台认证:
claude auth login --console用于API密钥计费 - SSO认证:
claude auth login --sso用于企业版 - 检查状态:
claude auth status(JSON格式)或claude auth status --text(人类可读格式) - 健康检查:
claude doctor— 检查自动更新程序和安装健康状态 - 版本检查:
claude --version(需要v2.x+) - 更新:
claude update或claude upgrade
两种编排模式
Hermes通过两种根本不同的方式与Claude Code交互。根据任务选择模式。
模式1:打印模式(-p)— 非交互式(大多数任务的首选)
打印模式运行一次性任务,返回结果后退出。无需PTY。无交互提示。这是最简洁的集成路径。
terminal(command="claude -p '为src/中所有API调用添加错误处理' --allowedTools 'Read,Edit' --max-turns 10", workdir="/path/to/project", timeout=120)
何时使用打印模式:
- 一次性编码任务(修复bug、添加功能、重构)
- CI/CD自动化和脚本编写
- 使用
--json-schema进行结构化数据提取 - 管道输入处理(
cat file | claude -p "分析这个") - 任何不需要多轮对话的任务
打印模式会跳过所有交互对话框 — 无工作区信任提示,无权限确认。这使其非常适合自动化。
模式2:通过tmux的交互式PTY — 多轮会话
交互模式提供完整的对话式REPL,您可以在其中发送后续提示、使用斜杠命令并实时观察Claude工作。需要tmux编排。
# 启动一个tmux会话
terminal(command="tmux new-session -d -s claude-work -x 140 -y 40")
# 在其中启动Claude Code
terminal(command="tmux send-keys -t claude-work 'cd /path/to/project && claude' Enter")
# 等待启动,然后发送您的任务
# (等待欢迎屏幕出现约3-5秒后)
terminal(command="sleep 5 && tmux send-keys -t claude-work '将auth模块重构为使用JWT令牌' Enter")
# 通过捕获窗格监控进度
terminal(command="sleep 15 && tmux capture-pane -t claude-work -p -S -50")
# 发送后续任务
terminal(command="tmux send-keys -t claude-work '现在为新的JWT代码添加单元测试' Enter")
# 完成后退出
terminal(command="tmux send-keys -t claude-work '/exit' Enter")
何时使用交互模式:
- 多轮迭代工作(重构 → 审查 → 修复 → 测试循环)
- 需要人类参与决策的任务
- 探索性编码会话
- 当您需要使用Claude的斜杠命令时(
/compact、/review、/model)
PTY对话框处理(交互模式的关键)
Claude Code在首次启动时会显示最多两个确认对话框。您必须通过tmux send-keys处理它们:
对话框1:工作区信任(首次访问目录时)
❯ 1. 是的,我信任此文件夹 ← 默认选项(直接按回车)
2. 不,退出
处理方法: tmux send-keys -t <会话名称> Enter — 默认选择是正确的。
对话框2:跳过权限警告(仅在使用--dangerously-skip-permissions时)
❯ 1. 不,退出 ← 默认选项(错误的选择!)
2. 是的,我接受
处理方法: 必须先向下导航,然后按回车:
tmux send-keys -t <会话名称> Down && sleep 0.3 && tmux send-keys -t <会话名称> Enter
稳健的对话框处理模式
# 使用权限绕过启动
terminal(command="tmux send-keys -t claude-work 'claude --dangerously-skip-permissions \"您的任务\"' Enter")
# 处理信任对话框(按回车选择默认的"是")
terminal(command="sleep 4 && tmux send-keys -t claude-work Enter")
# 处理权限对话框(按向下箭头然后回车选择"是,我接受")
terminal(command="sleep 3 && tmux send-keys -t claude-work Down && sleep 0.3 && tmux send-keys -t claude-work Enter")
# 现在等待Claude工作
terminal(command="sleep 15 && tmux capture-pane -t claude-work -p -S -60")
注意: 首次为目录接受信任后,信任对话框将不再出现。只有在使用--dangerously-skip-permissions时,权限对话框才会重复出现。
CLI子命令
| 子命令 | 用途 |
|---|---|
claude | 启动交互式REPL |
claude "查询" | 使用初始提示启动REPL |
claude -p "查询" | 打印模式(非交互式,完成后退出) |
cat file | claude -p "查询" | 通过管道将内容作为标准输入上下文传递 |
claude -c | 继续此目录中最近的对话 |
claude -r "id" | 通过ID或名称恢复特定会话 |
claude auth login | 登录(添加--console进行API计费,--sso用于企业版) |
claude auth status | 检查登录状态(返回JSON;--text用于人类可读格式) |
claude mcp add <name> -- <cmd> | 添加MCP服务器 |
claude mcp list | 列出已配置的MCP服务器 |
claude mcp remove <name> | 移除MCP服务器 |
claude agents | 列出已配置的智能体 |
claude doctor | 对安装和自动更新程序运行健康检查 |
claude update / claude upgrade | 将Claude Code更新到最新版本 |
claude remote-control | 启动服务器以从claude.ai或移动应用控制Claude |
claude install [target] | 安装原生构建版本(稳定版、最新版或特定版本) |
claude setup-token | 设置长期有效的认证令牌(需要订阅) |
claude plugin / claude plugins | 管理Claude Code插件 |
claude auto-mode | 检查自动模式分类器配置 |
打印模式深入探讨
结构化JSON输出
terminal(command="claude -p '分析auth.py的安全问题' --output-format json --max-turns 5", workdir="/project", timeout=120)
返回一个JSON对象:
{
"type": "result",
"subtype": "success",
"result": "分析文本...",
"session_id": "75e2167f-...",
"num_turns": 3,
"total_cost_usd": 0.0787,
"duration_ms": 10276,
"stop_reason": "end_turn",
"terminal_reason": "completed",
"usage": { "input_tokens": 5, "output_tokens": 603, ... },
"modelUsage": { "claude-sonnet-4-6": { "costUSD": 0.078, "contextWindow": 200000 } }
}
关键字段: session_id用于恢复,num_turns表示智能体循环次数,total_cost_usd用于支出跟踪,subtype用于成功/错误检测(success、error_max_turns、error_budget)。
流式JSON输出
对于实时令牌流,使用带有--verbose的stream-json:
terminal(command="claude -p '写一个摘要' --output-format stream-json --verbose --include-partial-messages", timeout=60)
返回换行符分隔的JSON事件。使用jq过滤实时文本:
claude -p "解释X" --output-format stream-json --verbose --include-partial-messages | \
jq -rj 'select(.type == "stream_event" and .event.delta.type? == "text_delta") | .event.delta.text'
流事件包括system/api_retry,包含attempt、max_retries和error字段(例如rate_limit、billing_error)。
双向流
用于实时输入和输出流:
claude -p "任务" --input-format stream-json --output-format stream-json --replay-user-messages
--replay-user-messages在标准输出上重新发出用户消息以进行确认。
管道输入
# 通过管道传递文件以进行分析
terminal(command="cat src/auth.py | claude -p '审查此代码中的bug' --max-turns 1", timeout=60)
# 通过管道传递多个文件
terminal(command="cat src/*.py | claude -p '查找所有TODO注释' --max-turns 1", timeout=60)
# 通过管道传递命令输出
terminal(command="git diff HEAD~3 | claude -p '总结这些更改' --max-turns 1", timeout=60)
用于结构化提取的JSON Schema
terminal(command="claude -p '列出src/中的所有函数' --output-format json --json-schema '{\"type\":\"object\",\"properties\":{\"functions\":{\"type\":\"array\",\"items\":{\"type\":\"string\"}}},\"required\":[\"functions\"]}' --max-turns 5", workdir="/project", timeout=90)
从JSON结果中解析structured_output。Claude在返回前会根据模式验证输出。
会话延续
# 开始一个任务
terminal(command="claude -p '开始重构数据库层' --output-format json --max-turns 10 > /tmp/session.json", workdir="/project", timeout=180)
# 使用会话ID恢复
terminal(command="claude -p '继续并添加连接池' --resume $(cat /tmp/session.json | python3 -c 'import json,sys; print(json.load(sys.stdin)[\"session_id\"])') --max-turns 5", workdir="/project", timeout=120)
# 或恢复同一目录中最近的会话
terminal(command="claude -p '你上次做了什么?' --continue --max-turns 1", workdir="/project", timeout=30)
# 分叉会话(新ID,保留历史记录)
terminal(command="claude -p '尝试不同的方法' --resume <id> --fork-session --max-turns 10", workdir="/project", timeout=120)
用于CI/脚本的裸模式
terminal(command="claude --bare -p '运行所有测试并报告失败项' --allowedTools 'Read,Bash' --max-turns 10", workdir="/project", timeout=180)
--bare跳过钩子、插件、MCP发现和CLAUDE.md加载。启动最快。需要ANTHROPIC_API_KEY(跳过OAuth)。
要在裸模式下选择性加载上下文:
| 要加载的内容 | 标志 |
|---|---|
| 系统提示附加内容 | --append-system-prompt "文本" 或 --append-system-prompt-file 路径 |
| 设置 | --settings <文件或JSON> |
| MCP服务器 | --mcp-config <文件或JSON> |
| 自定义智能体 | --agents '<JSON>' |
过载时的备用模型
terminal(command="claude -p '任务' --fallback-model haiku --max-turns 5", timeout=90)
当默认模型过载时,自动回退到指定模型(仅限打印模式)。
完整 CLI 标志参考
会话与环境
| 标志 | 效果 |
|---|---|
-p, --print | 非交互式单次模式(完成后退出) |
-c, --continue | 恢复当前目录中最近的会话 |
-r, --resume <id> | 通过 ID 或名称恢复特定会话(如果未提供 ID 则启动交互式选择器) |
--fork-session | 恢复时,创建新的会话 ID 而非重用原始会话 ID |
--session-id <uuid> | 为对话使用特定的 UUID |
--no-session-persistence | 不将会话保存到磁盘(仅限打印模式) |
--add-dir <paths...> | 授予 Claude 对其他工作目录的访问权限 |
-w, --worktree [name] | 在 .claude/worktrees/<name> 的独立 git 工作树中运行 |
--tmux | 为工作树创建 tmux 会话(需要 --worktree) |
--ide | 启动时自动连接到有效的 IDE |
--chrome / --no-chrome | 启用/禁用用于 Web 测试的 Chrome 浏览器集成 |
--from-pr [number] | 恢复链接到特定 GitHub PR 的会话 |
--file <specs...> | 启动时要下载的文件资源(格式:file_id:relative_path) |
模型与性能
| 标志 | 效果 |
|---|---|
--model <alias> | 模型选择:sonnet, opus, haiku,或完整名称如 claude-sonnet-4-6 |
--effort <level> | 推理深度:low, medium, high, max, auto |
--max-turns <n> | 限制智能体循环(仅限打印模式;防止失控) |
--max-budget-usd <n> | 限制 API 支出(以美元计,仅限打印模式) |
--fallback-model <model> | 默认模型过载时自动回退(仅限打印模式) |
--betas <betas...> | 要在 API 请求中包含的 Beta 头信息(仅限 API 密钥用户) |
权限与安全
| 标志 | 效果 |
|---|---|
--dangerously-skip-permissions | 自动批准所有工具使用(文件写入、bash、网络等) |
--allow-dangerously-skip-permissions | 将此绕过项作为选项启用,但默认不启用 |
--permission-mode <mode> | default, acceptEdits, plan, auto, dontAsk, bypassPermissions |
--allowedTools <tools...> | 将特定工具列入白名单(逗号或空格分隔) |
--disallowedTools <tools...> | 将特定工具列入黑名单 |
--tools <tools...> | 覆盖内置工具集("" = 无,"default" = 全部,或指定工具名称) |
输出与输入格式
| 标志 | 效果 |
|---|---|
--output-format <fmt> | text(默认),json(单个结果对象),stream-json(换行分隔) |
--input-format <fmt> | text(默认)或 stream-json(实时流式输入) |
--json-schema <schema> | 强制输出匹配特定模式的结构化 JSON |
--verbose | 完整的逐轮次输出 |
--include-partial-messages | 包含到达时的部分消息块(stream-json + print 模式) |
--replay-user-messages | 在标准输出重新发出用户消息(stream-json 双向模式) |
系统提示与上下文
| 标志 | 效果 |
|---|---|
--append-system-prompt <text> | 添加到默认系统提示(保留内置能力) |
--append-system-prompt-file <path> | 将文件内容添加到默认系统提示 |
--system-prompt <text> | 替换整个系统提示(通常建议使用 --append) |
--system-prompt-file <path> | 用文件内容替换系统提示 |
--bare | 跳过钩子、插件、MCP 发现、CLAUDE.md、OAuth(启动最快) |
--agents '<json>' | 动态定义自定义子智能体(JSON 格式) |
--mcp-config <path> | 从 JSON 文件加载 MCP 服务器(可重复) |
--strict-mcp-config | 仅使用来自 --mcp-config 的 MCP 服务器,忽略所有其他 MCP 配置 |
--settings <file-or-json> | 从 JSON 文件或内联 JSON 加载额外设置 |
--setting-sources <sources> | 逗号分隔的加载来源:user, project, local |
--plugin-dir <paths...> | 为此会话从目录加载插件 |
--disable-slash-commands | 禁用所有技能/斜杠命令 |
调试
| 标志 | 效果 |
|---|---|
-d, --debug [filter] | 启用调试日志记录,可选类别过滤器(例如 "api,hooks", "!1p,!file") |
--debug-file <path> | 将调试日志写入文件(隐式启用调试模式) |
智能体团队
| 标志 | 效果 |
|---|---|
--teammate-mode <mode> | 智能体团队的显示方式:auto, in-process 或 tmux |
--brief | 启用 SendUserMessage 工具以实现智能体与用户通信 |
--allowedTools / --disallowedTools 的工具名称语法
Read # 所有文件读取操作
Edit # 文件编辑(现有文件)
Write # 文件创建(新文件)
Bash # 所有 shell 命令
Bash(git *) # 仅 git 命令
Bash(git commit *) # 仅 git commit 命令
Bash(npm run lint:*) # 使用通配符的模式匹配
WebSearch # 网页搜索能力
WebFetch # 网页获取
mcp__<server>__<tool> # 特定 MCP 工具
设置与配置
设置层级(优先级从高到低)
- CLI 标志 — 覆盖所有其他设置
- 本地项目:
.claude/settings.local.json(个人使用,已被git忽略) - 项目:
.claude/settings.json(团队共享,由git跟踪) - 用户:
~/.claude/settings.json(全局)
设置中的权限
{
"permissions": {
"allow": ["Bash(npm run lint:*)", "WebSearch", "Read"],
"ask": ["Write(*.ts)", "Bash(git push*)"],
"deny": ["Read(.env)", "Bash(rm -rf *)"]
}
}
记忆文件(CLAUDE.md)层级
- 全局:
~/.claude/CLAUDE.md— 适用于所有项目 - 项目:
./CLAUDE.md— 项目特定上下文(由git跟踪) - 本地:
.claude/CLAUDE.local.md— 个人项目覆盖(已被git忽略)
在交互模式下使用 # 前缀快速添加记忆:# 始终使用 2 空格缩进。
交互会话:斜杠命令
会话与上下文
| 命令 | 用途 |
|---|---|
/help | 显示所有命令(包括自定义和 MCP 命令) |
/compact [focus] | 压缩上下文以节省token;CLAUDE.md 在压缩后会保留。例如,/compact focus on auth logic |
/clear | 清空对话历史,重新开始 |
/context | 将上下文使用情况可视化为彩色网格,并提供优化提示 |
/cost | 查看 token 使用量,包括按模型和缓存命中率细分 |
/resume | 切换或恢复到不同的会话 |
/rewind | 回退到对话或代码的先前检查点 |
/btw <question> | 提出一个侧边问题,不增加上下文成本 |
/status | 显示版本、连接性和会话信息 |
/todos | 列出对话中跟踪的待办事项 |
/exit 或 Ctrl+D | 结束会话 |
开发与审查
| 命令 | 用途 |
|---|---|
/review | 请求对当前更改进行代码审查 |
/security-review | 对当前更改执行安全分析 |
/plan [description] | 进入计划模式,自动开始任务规划 |
/loop [interval] | 在会话中安排周期性任务 |
/batch | 为大型并行更改自动创建工作树(5-30 个工作树) |
配置与工具
| 命令 | 用途 |
|---|---|
/model [model] | 会话中途切换模型(使用方向键调整投入程度) |
/effort [level] | 设置推理投入程度:low、medium、high、max 或 auto |
/init | 创建用于项目记忆的 CLAUDE.md 文件 |
/memory | 打开 CLAUDE.md 进行编辑 |
/config | 打开交互式设置配置 |
/permissions | 查看/更新工具权限 |
/agents | 管理专门的子智能体 |
/mcp | 管理 MCP 服务器的交互式 UI |
/add-dir | 添加额外的工作目录(适用于 monorepo) |
/usage | 显示计划限额和速率限制状态 |
/voice | 启用按键说话的语音模式(20 种语言;按住 Space 录音,松开发送) |
/release-notes | 版本发布说明的交互式选择器 |
自定义斜杠命令
在 .claude/commands/<name>.md(项目共享)或 ~/.claude/commands/<name>.md(个人)中创建:
# .claude/commands/deploy.md
运行部署管道:
1. 运行所有测试
2. 构建 Docker 镜像
3. 推送到注册表
4. 更新 $ARGUMENTS 环境(默认:staging)
用法:/deploy production — $ARGUMENTS 将被用户的输入替换。
技能(自然语言调用)
与斜杠命令(手动调用)不同,.claude/skills/ 中的技能是 Markdown 指南,Claude 会在任务匹配时通过自然语言自动调用:
# .claude/skills/database-migration.md
当被要求创建或修改数据库迁移时:
1. 使用 Alembic 生成迁移
2. 始终创建回滚函数
3. 针对本地数据库副本测试迁移
交互会话:键盘快捷键
常规控制
| 按键 | 操作 |
|---|---|
Ctrl+C | 取消当前输入或生成 |
Ctrl+D | 退出会话 |
Ctrl+R | 反向搜索命令历史 |
Ctrl+B | 将正在运行的任务置于后台 |
Ctrl+V | 将图像粘贴到对话中 |
Ctrl+O | 转录模式 — 查看 Claude 的思考过程 |
Ctrl+G 或 Ctrl+X Ctrl+E | 在外部编辑器中打开提示 |
Esc Esc | 回退对话或代码状态 / 总结 |
模式切换
| 按键 | 操作 |
|---|---|
Shift+Tab | 循环权限模式(普通 → 自动接受 → 计划) |
Alt+P | 切换模型 |
Alt+T | 切换思考模式 |
Alt+O | 切换快速模式 |
多行输入
| 按键 | 操作 |
|---|---|
\ + Enter | 快速换行 |
Shift+Enter | 换行(替代方式) |
Ctrl+J | 换行(替代方式) |
输入前缀
| 前缀 | 操作 |
|---|---|
! | 直接执行 bash,绕过 AI(例如 !npm test)。单独使用 ! 可切换 shell 模式。 |
@ | 通过自动补全引用文件/目录(例如 @./src/api/) |
# | 快速添加到 CLAUDE.md 记忆(例如 # 使用 2 空格缩进) |
/ | 斜杠命令 |
专业提示:“ultrathink”
在您的提示中使用关键字 "ultrathink",以在特定轮次启用最大推理投入。无论当前的 /effort 设置如何,这都会触发最深层次的思考模式。
PR 审查模式
快速审查(打印模式)
terminal(command="cd /path/to/repo && git diff main...feature-branch | claude -p 'Review this diff for bugs, security issues, and style problems. Be thorough.' --max-turns 1", timeout=60)
深度审查(交互式 + 工作树)
terminal(command="tmux new-session -d -s review -x 140 -y 40")
terminal(command="tmux send-keys -t review 'cd /path/to/repo && claude -w pr-review' Enter")
terminal(command="sleep 5 && tmux send-keys -t review Enter") # 信任对话框
terminal(command="sleep 2 && tmux send-keys -t review 'Review all changes vs main. Check for bugs, security issues, race conditions, and missing tests.' Enter")
terminal(command="sleep 30 && tmux capture-pane -t review -p -S -60")
从 PR 编号进行审查
terminal(command="claude -p 'Review this PR thoroughly' --from-pr 42 --max-turns 10", workdir="/path/to/repo", timeout=120)
使用 tmux 的 Claude 工作树
terminal(command="claude -w feature-x --tmux", workdir="/path/to/repo")
会在 .claude/worktrees/feature-x 创建一个隔离的 git 工作树并为其创建一个 tmux 会话。可用时会使用 iTerm2 原生窗格;添加 --tmux=classic 可使用传统 tmux。
并行 Claude 实例
同时运行多个独立的 Claude 任务:
# 任务 1:修复后端
terminal(command="tmux new-session -d -s task1 -x 140 -y 40 && tmux send-keys -t task1 'cd ~/project && claude -p \"Fix the auth bug in src/auth.py\" --allowedTools \"Read,Edit\" --max-turns 10' Enter")
# 任务 2:编写测试
terminal(command="tmux new-session -d -s task2 -x 140 -y 40 && tmux send-keys -t task2 'cd ~/project && claude -p \"Write integration tests for the API endpoints\" --allowedTools \"Read,Write,Bash\" --max-turns 15' Enter")
# 任务 3:更新文档
terminal(command="tmux new-session -d -s task3 -x 140 -y 40 && tmux send-keys -t task3 'cd ~/project && claude -p \"Update README.md with the new API endpoints\" --allowedTools \"Read,Edit\" --max-turns 5' Enter")
# 监控所有任务
terminal(command="sleep 30 && for s in task1 task2 task3; do echo '=== '$s' ==='; tmux capture-pane -t $s -p -S -5 2>/dev/null; done")
# 项目:我的 API
## 架构
- 使用 SQLAlchemy ORM 的 FastAPI 后端
- PostgreSQL 数据库,Redis 缓存
- 使用 pytest 进行测试,目标覆盖率为 90%
## 关键命令
- `make test` — 运行完整测试套件
- `make lint` — ruff + mypy
- `make dev` — 在 :8000 启动开发服务器
## 代码标准
- 所有公共函数使用类型提示
- 使用 Google 风格的文档字符串
- YAML 使用 2 空格缩进,Python 使用 4 空格缩进
- 禁止通配符导入
要具体明确。 不要说“编写好的代码”,而要说“对 JS 使用 2 空格缩进”或“测试文件使用 .test.ts 后缀。”具体的指令能节省纠正的循环。
规则目录(模块化 CLAUDE.md)
对于规则很多的项目,请使用规则目录,而不是一个庞大的 CLAUDE.md:
- 项目规则:
.claude/rules/*.md— 团队共享,受版本控制 - 用户规则:
~/.claude/rules/*.md— 个人全局规则
规则目录中的每个 .md 文件都会作为额外的上下文加载。这比将所有内容塞进单个 CLAUDE.md 更清晰。
自动记忆
Claude 会自动将学习到的项目上下文存储在 ~/.claude/projects/<project>/memory/。
- 限制: 每个项目 25KB 或 200 行
- 这与 CLAUDE.md 分开 — 是 Claude 自己对项目的笔记,跨会话累积。
自定义子智能体
在 .claude/agents/(项目)、~/.claude/agents/(个人)或通过 --agents CLI 标志(会话)定义专门的智能体:
智能体位置优先级
.claude/agents/— 项目级,团队共享--agentsCLI 标志 — 会话特定,动态~/.claude/agents/— 用户级,个人
创建智能体
# .claude/agents/security-reviewer.md
---
name: security-reviewer
description: 专注于安全的代码审查
model: opus
tools: [Read, Bash]
---
你是一位资深的安全工程师。审查代码以发现:
- 注入漏洞(SQL, XSS, 命令注入)
- 认证/授权缺陷
- 代码中的密钥
- 不安全的反序列化
通过以下方式调用:@security-reviewer 审查认证模块
通过 CLI 动态创建智能体
terminal(command="claude --agents '{\"reviewer\": {\"description\": \"审查代码\", \"prompt\": \"你是一位专注于性能的代码审查员\"}}' -p '使用 @reviewer 检查 auth.py'", timeout=120)
Claude 可以编排多个智能体:“使用 @db-expert 优化查询,然后使用 @security 审计更改。”
Hooks — 事件自动化
在 .claude/settings.json(项目)或 ~/.claude/settings.json(全局)中配置:
{
"hooks": {
"PostToolUse": [{
"matcher": "Write(*.py)",
"hooks": [{"type": "command", "command": "ruff check --fix $CLAUDE_FILE_PATHS"}]
}],
"PreToolUse": [{
"matcher": "Bash",
"hooks": [{"type": "command", "command": "if echo \"$CLAUDE_TOOL_INPUT\" | grep -q 'rm -rf'; then echo '已阻止!' && exit 2; fi"}]
}],
"Stop": [{
"hooks": [{"type": "command", "command": "echo 'Claude 完成了一个响应' >> /tmp/claude-activity.log"}]
}]
}
}
所有 8 种 Hook 类型
| Hook | 触发时机 | 常见用途 |
|---|---|---|
UserPromptSubmit | 在 Claude 处理用户提示之前 | 输入验证,日志记录 |
PreToolUse | 工具执行前 | 安全门禁,阻止危险命令(exit 2 = 阻止) |
PostToolUse | 工具完成后 | 自动格式化代码,运行检查器 |
Notification | 权限请求或等待输入时 | 桌面通知,警报 |
Stop | 当 Claude 完成一个响应时 | 完成日志记录,状态更新 |
SubagentStop | 当子智能体完成时 | 智能体编排 |
PreCompact | 在清除上下文内存之前 | 备份会话记录 |
SessionStart | 当会话开始时 | 加载开发上下文(例如 git status) |
Hook 环境变量
| 变量 | 内容 |
|---|---|
CLAUDE_PROJECT_DIR | 当前项目路径 |
CLAUDE_FILE_PATHS | 正在修改的文件 |
CLAUDE_TOOL_INPUT | 工具参数(JSON 格式) |
安全 Hook 示例
{
"PreToolUse": [{
"matcher": "Bash",
"hooks": [{"type": "command", "command": "if echo \"$CLAUDE_TOOL_INPUT\" | grep -qE 'rm -rf|git push.*--force|:(){ :|:& };:'; then echo '危险命令已阻止!' && exit 2; fi"}]
}]
}
MCP 集成
为数据库、API 和服务添加外部工具服务器:
# GitHub 集成
terminal(command="claude mcp add -s user github -- npx @modelcontextprotocol/server-github", timeout=30)
# PostgreSQL 查询
terminal(command="claude mcp add -s local postgres -- npx @anthropic-ai/server-postgres --connection-string postgresql://localhost/mydb", timeout=30)
# Puppeteer 用于网页测试
terminal(command="claude mcp add puppeteer -- npx @anthropic-ai/server-puppeteer", timeout=30)
MCP 作用域
| 标志 | 作用域 | 存储位置 |
|---|---|---|
-s user | 全局(所有项目) | ~/.claude.json |
-s local | 此项目(个人) | .claude/settings.local.json(被 git 忽略) |
-s project | 此项目(团队共享) | .claude/settings.json(受版本控制) |
在 Print/CI 模式下使用 MCP
terminal(command="claude --bare -p '查询数据库' --mcp-config mcp-servers.json --strict-mcp-config", timeout=60)
--strict-mcp-config 会忽略除了来自 --mcp-config 之外的所有 MCP 服务器。
在聊天中引用 MCP 资源:@github:issue://123
MCP 限制与调优
- 工具描述: 每个服务器的工具描述和服务器说明上限为 2KB
- 结果大小: 默认上限;使用
maxResultSizeChars注解可允许最多 500K 个字符用于大输出 - 输出令牌:
export MAX_MCP_OUTPUT_TOKENS=50000— 限制来自 MCP 服务器的输出,防止上下文溢出 - 传输协议:
stdio(本地进程)、http(远程)、sse(服务器推送事件)
监控交互式会话
读取 TUI 状态
# 定期捕获以检查 Claude 是否仍在工作或等待输入
terminal(command="tmux capture-pane -t dev -p -S -10")
寻找以下指示器:
- 底部的
❯= 等待你的输入(Claude 完成或正在提问) - 带有
●的行 = Claude 正在积极使用工具(读取、写入、运行命令) ⏵⏵ bypass permissions on= 状态栏显示权限模式◐ medium · /effort= 状态栏中的当前努力级别ctrl+o to expand= 工具输出被截断(可以交互式展开)
上下文窗口健康度
在交互模式下使用 /context 可以看到上下文使用的彩色网格。关键阈值:
- < 70% — 正常操作,精度最高
- 70-85% — 精度开始下降,考虑使用
/compact - > 85% — 幻觉风险显著增加,使用
/compact或/clear
环境变量
| 变量 | 效果 |
|---|---|
ANTHROPIC_API_KEY | 用于认证的 API 密钥(OAuth 的替代方案) |
CLAUDE_CODE_EFFORT_LEVEL | 默认努力级别:low, medium, high, max, 或 auto |
MAX_THINKING_TOKENS | 限制思考令牌(设置为 0 可完全禁用思考) |
MAX_MCP_OUTPUT_TOKENS | 限制来自 MCP 服务器的输出(默认值不同;例如设置为 50000) |
CLAUDE_CODE_NO_FLICKER=1 | 启用备用屏幕渲染以消除终端闪烁 |
CLAUDE_CODE_SUBPROCESS_ENV_SCRUB | 从子进程中删除凭证以确保安全 |
成本与性能提示
- 在打印模式下使用
--max-turns以防止失控循环。对于大多数任务,从 5-10 开始。 - 使用
--max-budget-usd设置成本上限。注意:创建系统提示缓存的最低成本约为 0.05 美元。 - 对简单任务使用
--effort low(更快,更便宜)。对于复杂的推理使用high或max。 - 在 CI/脚本中使用
--bare以跳过插件/钩子发现的开销。 - 使用
--allowedTools限制只使用需要的工具(例如,仅审查时使用Read)。 - 在上下文变大时,在交互会话中使用
/compact。 - 当只需要分析已知内容时,使用管道输入 而不是让 Claude 读取文件。
- 对简单任务使用
--model haiku(更便宜),对复杂的多步骤工作使用--model opus。 - 在打印模式下使用
--fallback-model haiku以优雅地处理模型过载。 - 为不同的任务启动新的会话 — 会话持续 5 小时;新上下文更高效。
- 在 CI 中使用
--no-session-persistence以避免在磁盘上积累已保存的会话。
## 陷阱和注意事项
1. **交互模式需要 tmux** — Claude Code 是一个完整的 TUI 应用程序。在 Hermes 终端中仅使用 `pty=true` 可以工作,但 tmux 提供 `capture-pane` 用于监控和 `send-keys` 用于输入,这对编排至关重要。
2. **`--dangerously-skip-permissions` 对话框默认为"否,退出"** — 您必须先按向下箭头键,然后按回车键来接受。打印模式(`-p`)会完全跳过此步骤。
3. **`--max-budget-usd` 最低约为 $0.05** — 仅系统提示缓存创建就会花费这么多。设置更低的值会立即报错。
4. **`--max-turns` 仅适用于打印模式** — 在交互式会话中会被忽略。
5. **Claude 可能会使用 `python` 而不是 `python3`** — 在没有 `python` 符号链接的系统上,Claude 的 bash 命令首次执行会失败,但它会自动纠正。
6. **会话恢复需要相同的目录** — `--continue` 会查找当前工作目录中最近的会话。
7. **`--json-schema` 需要足够的 `--max-turns`** — Claude 在生成结构化输出之前必须读取文件,这需要多个轮次。
8. **信任对话框每个目录只出现一次** — 仅首次出现,之后会缓存。
9. **后台 tmux 会话会持续存在** — 完成后始终使用 `tmux kill-session -t <名称>` 进行清理。
10. **斜杠命令(如 `/commit`)仅在交互模式下有效** — 在 `-p` 模式下,请用自然语言描述任务。
11. **`--bare` 跳过 OAuth** — 需要设置环境变量 `ANTHROPIC_API_KEY` 或配置中的 `apiKeyHelper`。
12. **上下文退化是真实存在的** — 当上下文窗口使用率超过 70% 时,AI 输出质量会明显下降。使用 `/context` 监控并主动执行 `/compact`。
## Hermes 智能体规则
1. **单任务优先使用打印模式(`-p`)** — 更简洁,无需处理对话框,支持结构化输出
2. **多轮交互工作使用 tmux** — 编排 TUI 的唯一可靠方式
3. **始终设置 `workdir`** — 让 Claude 专注于正确的项目目录
4. **在打印模式下设置 `--max-turns`** — 防止无限循环和成本失控
5. **监控 tmux 会话** — 使用 `tmux capture-pane -t <会话名> -p -S -50` 检查进度
6. **留意 `❯` 提示符** — 表示 Claude 正在等待输入(已完成或正在提问)
7. **清理 tmux 会话** — 完成后终止它们以避免资源泄漏
8. **向用户报告结果** — 完成后,总结 Claude 执行的操作和发生的变更
9. **不要终止缓慢的会话** — Claude 可能正在执行多步骤工作;请检查进度
10. **使用 `--allowedTools`** — 将功能限制为任务实际需要的范围