如果你已经用了一段时间 OpenClaw,肯定会遇到这样的需求:我需要一个专门写博客的 AI 助手,一个写小说的,一个做代码开发的……每个都有独立的角色定位、工作目录和配置。这就是多 Agent 配置要解决的问题。
本文不是理论教程,而是实战踩坑记录。我会告诉你配置过程中会遇到哪些坑,为什么会踩坑,以及怎么避免和解决。
场景隔离。不同的工作场景需要不同的 AI 助手:
- 博客助手:专注于技术写作,熟悉你的博客部署流程,有独立的文章草稿目录
- 小说助手:创意写作风格,管理小说章节和人物设定,不需要访问技术代码
- 开发助手:熟悉代码规范,可以执行敏感命令,但不应该访问私人笔记
- 家庭助手:绑定到家庭 WhatsApp 群,只能访问受限的工具集,保护隐私
独立配置。每个 Agent 有自己的:
- Workspace:独立的工作目录,互不干扰
- SOUL.md:独立的角色定位和性格设定
- Model:可以给不同 Agent 配置不同模型(Opus 做深度思考,Sonnet 做日常聊天)
- Tool Policy:限制某些 Agent 的工具权限(比如家庭助手不能执行 shell 命令)
账号路由。多个 Telegram bot 或 WhatsApp 账号,路由到不同的 Agent,一个 Gateway 管理所有账号。
举个例子,你可能会配置这样的 Agent:
- main:日常聊天,全功能
- work:工作场景,可以访问项目文档
- creative:创作助手,专注于写作
- coding:开发助手,执行代码相关任务
GPT plus 代充 只需 145# 创建一个新 Agent openclaw agents add blog --workspace ~/.openclaw/workspace-blog # 验证创建结果 openclaw agents list
这会在配置文件中添加:
{ agents: { list: [ { id: "main", default: true, workspace: "~/.openclaw/workspace", }, { id: "blog", workspace: "~/.openclaw/workspace-blog", }, ], }, }
⚠️ 第一个坑:模型 ID 格式
配置模型时,要用别名,不要带日期后缀!
GPT plus 代充 只需 145# ✅ 正确:使用别名 openclaw config patch agents.list.1.model "anthropic/claude-sonnet-4-5" # ❌ 错误:带日期后缀的完整 ID openclaw config patch agents.list.1.model "anthropic/claude-sonnet-4-"
为什么?
带日期的 ID 会在新版本发布时失效。别名(如 claude-sonnet-4-5)会自动指向最新版本。
验证配置:
openclaw config get agents.list.1.model # 应该输出:anthropic/claude-sonnet-4-5
每个 Agent 的 workspace 下创建 SOUL.md,定义它的角色:
GPT plus 代充 只需 145cd ~/.openclaw/workspace-blog
创建 SOUL.md:
# SOUL.md - 工作助手 你是工作助手,帮助处理日常工作任务。 角色定位 - 专注于工作场景,风格专业高效 - 熟悉常用开发工具和工作流程 - 所有重要操作需要确认后执行 工作流程 1. 接收任务需求 2. 分析任务并制定执行计划 3. 执行任务 4. 汇报结果 工作规范 - 代码示例要完整可用 - 文档结构清晰 - 操作前确认权限
⚠️ 第二个坑:不要创建 BOOTSTRAP.md
如果你手动创建了 BOOTSTRAP.md,Agent 会一直卡在 bootstrapping 状态!
为什么?
BOOTSTRAP.md 是 Agent 的"初始化任务清单"。Agent 启动后会执行里面的指令,执行完才会删除这个文件。如果你手动创建了这个文件但内容不完整,Agent 会不断尝试执行,永远无法进入正常状态。
解决方法:
GPT plus 代充 只需 145# 如果发现 Agent 卡住了,检查是否有 BOOTSTRAP.md ls ~/.openclaw/workspace-blog/BOOTSTRAP.md # 如果存在,直接删除 rm ~/.openclaw/workspace-blog/BOOTSTRAP.md # 重启 Gateway openclaw gateway restart
# 列出所有 Agent openclaw agents list # 查看 Agent 详细配置 openclaw config get agents.list.1 # 重启 Gateway 让配置生效 openclaw gateway restart
多 Agent 的典型用法是配置多个 Telegram bot,每个 bot 路由到不同的 Agent。
在 Telegram 找 @BotFather,创建 bot:
GPT plus 代充 只需 145/newbot
按提示输入名称和用户名,获得 token(类似 :ABCdefGHIjklMNOpqrsTUVwxyz)。
假设你创建了两个 bot:
- @MyMainBot → token1
- @MyWorkBot → token2
编辑 ~/.openclaw/openclaw.json(或用 openclaw config patch):
{ channels: { telegram: { accounts: { main: { token: "token1", dmPolicy: "allowlist", allowFrom: [""], // 你的 Telegram user ID }, blog: { token: "token2", dmPolicy: "allowlist", allowFrom: [""], }, }, }, }, }
⚠️ 第三个坑:dmPolicy 默认值
如果不设置 dmPolicy,默认是 pairing,这意味着用户必须先执行 /pair 命令才能聊天。但如果配置有问题,/pair 可能也不会响应,消息会被静默丢弃!
解决方法:
明确设置 dmPolicy: "allowlist",并配置 allowFrom 列表:
GPT plus 代充 只需 145{ dmPolicy: "allowlist", allowFrom: ["", ""], // 允许的 user ID 列表 }
获取你的 Telegram user ID:给 @userinfobot 发消息。
添加 bindings 将不同的 Telegram 账号路由到不同的 Agent:
{ bindings: [ { agentId: "main", match: { channel: "telegram", accountId: "main" }, }, { agentId: "blog", match: { channel: "telegram", accountId: "blog" }, }, ], }
路由规则优先级:
- peer 精确匹配(具体的 DM 或群组 ID)
- accountId 匹配(哪个 Telegram 账号)
- channel 匹配(哪个平台)
- 默认 Agent(default: true 或列表中第一个)
GPT plus 代充 只需 145openclaw gateway restart --reason "添加新 Telegram bot"
测试:给两个 bot 发 /start,应该分别收到来自不同 Agent 的回复。
现象:
我想给 telegram.accounts 添加一个新账号,执行:
openclaw config patch channels.telegram.accounts.blog '{"token":"xxx"}'
结果其他账号的配置全没了!
原因:
config.patch 对嵌套对象是整体替换,不是增量修改!
如果配置是:
GPT plus 代充 只需 145{ channels: { telegram: { accounts: { main: {...}, novel: {...}, }, }, }, }
执行 patch channels.telegram.accounts.blog {...} 会导致:
{ channels: { telegram: { accounts: { blog: {...}, // 只剩这一个! }, }, }, }
解决方法:
patch 时带上完整的对象:
GPT plus 代充 只需 145# ❌ 错误:只 patch 一个子项 openclaw config patch channels.telegram.accounts.blog '{"token":"xxx"}' # ✅ 正确:patch 整个 accounts 对象 openclaw config patch channels.telegram.accounts '{ "main": {"token":"token1", "dmPolicy":"allowlist", "allowFrom":[""]}, "blog": {"token":"token2", "dmPolicy":"allowlist", "allowFrom":[""]} }'
同样适用于 bindings、agents.list 等数组或对象。
**实践:
配置变更前,先导出当前配置:
# 导出当前配置 openclaw config get channels.telegram.accounts > telegram-accounts-backup.json # 编辑后再 patch 回去 openclaw config patch channels.telegram.accounts "$(cat telegram-accounts-edited.json)"
现象:
给 bot 发 /start 或任何消息,都没有回复。
可能的原因 1:dmPolicy 配置问题
检查配置:
GPT plus 代充 只需 145openclaw config get channels.telegram.accounts.blog.dmPolicy
如果是 pairing 或未设置,改成 allowlist:
openclaw config patch channels.telegram.accounts.blog.dmPolicy '"allowlist"' openclaw config patch channels.telegram.accounts.blog.allowFrom '[""]' openclaw gateway restart
可能的原因 2:Telegram 409 冲突
症状: 日志中有 getUpdates conflict (409) 错误。
原因: 同一个 bot token 被多个实例同时使用!常见场景:
- OpenClaw.app (GUI) 和 CLI gateway 同时运行
- 两个 terminal 同时启动了 gateway
检查:
GPT plus 代充 只需 145ps aux | grep -i openclaw
如果看到多个进程(GUI app 和 CLI gateway),说明冲突了。
解决方法:
- 退出 OpenClaw.app (GUI)
- 重启 CLI gateway:
openclaw gateway restart --reason "清除 Telegram bot 冲突"
教训:
同一个 Telegram bot token 只能被一个 Gateway 实例使用。如果要切换 GUI/CLI,必须先停掉其中一个。
现象:
配置了 bindings,但消息还是路由到了错误的 Agent。
检查绑定:
GPT plus 代充 只需 145openclaw agents list --bindings
常见错误:
- 顺序错误:更具体的规则要放在前面
// ❌ 错误:通配规则在前,精确规则在后 bindings: [ { agentId: "main", match: { channel: "telegram" } }, // 会匹配所有 telegram 消息 { agentId: "blog", match: { channel: "telegram", accountId: "blog" } }, // 永远不会执行 ] // ✅ 正确:精确规则在前 bindings: [ { agentId: "blog", match: { channel: "telegram", accountId: "blog" } }, { agentId: "main", match: { channel: "telegram", accountId: "main" } }, ]
- accountId 拼写错误:检查是否与
channels.telegram.accounts中的 key 一致
GPT plus 代充 只需 145# 列出所有配置的账号 openclaw config get channels.telegram.accounts | jq 'keys'
解决方法:
Gateway 需要重启才能加载新配置:
openclaw gateway restart --reason "更新 Agent 配置"
检查 Agent 是否正常启动:
GPT plus 代充 只需 145openclaw status --deep
如果看到某个 Agent 状态异常,查看日志:
tail -n 100 ~/.openclaw/gateway.err.log
现象:
我在顶层配置了 channels.telegram.dmPolicy,为什么某个账号还是用了不同的策略?
原因:
配置有继承关系,account 级别的配置会覆盖顶层配置:
GPT plus 代充 只需 145{ channels: { telegram: { dmPolicy: "allowlist", // 顶层默认 allowFrom: [""], accounts: { main: { token: "token1", // 继承顶层的 dmPolicy 和 allowFrom }, public: { token: "token2", dmPolicy: "pairing", // 覆盖顶层配置 }, }, }, }, }
**实践:
- 如果所有账号都用相同策略,配置在顶层
- 如果某个账号需要不同策略,在 account 级别覆盖
- 明确写出每个 account 的
dmPolicy,避免继承混淆
教训: 我曾因为没仔细审查 patch 命令,把所有 Telegram 账号配置冲掉,导致所有 bot 连接中断。
规则:
- 任何
config.patch、gateway restart、模型变更等操作,先审查一遍 - 嵌套对象(
bindings、accounts)必须带完整列表 - 有疑问先导出当前配置对比
# 变更前备份 openclaw config get > openclaw-config-backup.json # 变更后对比 openclaw config get > openclaw-config-new.json diff openclaw-config-backup.json openclaw-config-new.json
GPT plus 代充 只需 145openclaw status --deep
输出包括:
- 每个 Agent 的状态
- Channel 连接状态
- 最近的错误日志
如果某个 Agent 或 Channel 异常,会直接显示。
# 实时查看日志 tail -f ~/.openclaw/gateway.err.log # 搜索特定错误 grep -i "error|conflict|fail" ~/.openclaw/gateway.err.log | tail -n 50
常见错误关键词:
409 conflict:Telegram bot 冲突unauthorized:token 错误或过期dmPolicy:消息被访问控制策略拦截binding:路由规则问题
不要一次性配置所有 Agent 和 Channel,容易出错且难以排查。
推荐流程:
- 先配置一个新 Agent(不配置 Telegram),本地测试
- Agent 正常后,添加一个 Telegram bot,测试路由
- 验证通过后,再添加其他 Agent 和 bot
- 每次变更后,验证所有已有功能正常
在 workspace 下创建 SETUP.md,记录:
- 每个 Agent 的用途和配置
- Telegram bot 对应关系
- 特殊配置的原因
GPT plus 代充 只需 145# SETUP.md Agents - main: 日常聊天,全功能,Telegram @MyMainBot - blog: 技术写作,workspace-blog,Telegram @MyWorkBot - novel: 小说创作,workspace-novel,仅本地使用 Telegram Bots - @MyMainBot (): main agent - @MyWorkBot (): work agent 特殊配置 - work agent 的 dmPolicy 设为 allowlist,只允许授权用户访问 - main agent 启用了 heartbeat,定期检查日程
OpenClaw 多 Agent 配置不复杂,但有几个容易踩的坑:
- config.patch 陷阱:嵌套对象是整体替换,不是增量修改
- 模型 ID:用别名(
claude-sonnet-4-5),不要带日期 - BOOTSTRAP.md:不要手动创建,会导致 Agent 卡住
- dmPolicy:默认是
pairing,建议改成allowlist - Telegram 409:同一个 bot token 只能被一个 Gateway 使用
- 配置继承:account 级别配置会覆盖顶层配置
核心原则:
- 配置前先备份
- 变更后先验证
- 出问题先看日志
- 分阶段逐步配置
到此这篇关于OpenClaw多Agent配置实战及踩坑指南的文章就介绍到这了,更多相关OpenClaw多Agent配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/242275.html