令牌使用与成本

令牌使用与成本

适用范围

在以下情况使用此页面:

  • 解释令牌使用、成本或上下文窗口
  • 调试上下文增长或压缩行为

Clawdbot 跟踪令牌,而不是字符。令牌因模型而异,但对于英文文本,大多数 OpenAI 风格的模型平均每个令牌约 4 个字符。

系统提示的构建方式

Clawdbot 在每次运行时都会组装自己的系统提示。它包括:

  • 工具列表 + 简短描述
  • 技能列表(仅元数据;指令通过 read 按需加载)
  • 自更新指令
  • 工作区 + 引导文件(AGENTS.mdSOUL.mdTOOLS.mdIDENTITY.mdUSER.mdHEARTBEAT.md、新的 BOOTSTRAP.md)。大文件被 agents.defaults.bootstrapMaxChars 截断(默认:20000)。
  • 时间(UTC + 用户时区)
  • 回复标签 + 心跳行为
  • 运行时元数据(主机/操作系统/模型/思考)

完整分解请参阅 系统提示

上下文窗口中计算的内容

模型接收的所有内容都计入上下文限制:

  • 系统提示(上面列出的所有部分)
  • 对话历史(用户 + 助手消息)
  • 工具调用和工具结果
  • 附件/转录(图像、音频、文件)
  • 压缩摘要和修剪产物
  • 提供商包装器或安全标头(不可见,但仍计算)

对于实用分解(每个注入文件、工具、技能和系统提示大小),请使用 /context list/context detail。请参阅 上下文

如何查看当前令牌使用量

在聊天中使用这些命令:

  • /status表情符号丰富的状态卡,包含会话模型、上下文使用量、上次响应的输入/输出令牌以及预估成本(仅限 API 密钥)。
  • /usage off|tokens|full → 在每次回复后附加每响应使用页脚
    • 每个会话持久化(存储为 responseUsage)。
    • OAuth 认证隐藏成本(仅令牌)。
  • /usage cost → 显示 Clawdbot 会话日志的本地成本摘要。

其他界面:

  • TUI/Web TUI:支持 /status + /usage
  • CLIclawdbot status --usageclawdbot channels list 显示提供商配额窗口(而非每响应成本)。

成本估算(显示时)

成本从模型定价配置估算:

models.providers.<provider>.models[].cost

这些是 inputoutputcacheReadcacheWrite每 100 万令牌美元价格。如果缺少定价,Clawdbot 仅显示令牌。OAuth 令牌从不显示美元成本。

缓存 TTL 和修剪影响

提供商提示缓存仅在缓存 TTL 窗口内应用。Clawdbot 可以选择运行缓存 TTL 修剪:一旦缓存 TTL 过期,它会修剪会话,然后重置缓存窗口,以便后续请求可以重用新缓存的上下文,而不是重新缓存完整历史。当会话空闲超过 TTL 时,这可以保持较低的缓存写入成本。

网关配置 中配置它,并在 会话修剪 中查看行为详细信息。

心跳可以使缓存在空闲间隙中保持温暖。如果模型缓存 TTL 是 1h,将心跳间隔设置为略低于该值(例如 55m)可以避免重新缓存完整提示,从而降低缓存写入成本。

对于 Anthropic API 定价,缓存读取显著低于输入令牌,而缓存写入以更高的倍率计费。请参阅 Anthropic 的提示缓存定价以了解最新费率和 TTL 倍数: https://docs.anthropic.com/docs/build-with-claude/prompt-caching

示例:使用心跳保持 1h 缓存温暖

agents:
  defaults:
    model:
      primary: "anthropic/claude-opus-4-5"
    models:
      "anthropic/claude-opus-4-5":
        params:
          cacheControlTtl: "1h"
    heartbeat:
      every: "55m"

减少令牌压力的提示

  • 使用 /compact 来总结长会话。
  • 在工作流中修剪大型工具输出。
  • 保持技能描述简短(技能列表注入到提示中)。
  • 对于冗长、探索性工作,首选较小的模型。

确切的技能列表开销公式请参阅 技能