Multi-agent
Định tuyến đa tác nhân
Chạy nhiều agent cô lập — mỗi agent có workspace, thư mục trạng thái (agentDir) và lịch sử phiên riêng — cùng nhiều tài khoản kênh (ví dụ: hai WhatsApp) trong một Gateway đang chạy. Tin nhắn đến được định tuyến đến đúng agent thông qua các binding.
Ở đây, agent là toàn bộ phạm vi theo từng persona: tệp workspace, hồ sơ xác thực, sổ đăng ký model và kho phiên. agentDir là thư mục trạng thái trên đĩa chứa cấu hình theo từng agent này tại ~/.openclaw/agents/<agentId>/. binding ánh xạ một tài khoản kênh (ví dụ: một workspace Slack hoặc một số WhatsApp) đến một trong các agent đó.
"một agent" là gì?
agent là một bộ não được phân phạm vi đầy đủ với:
- Workspace (tệp, AGENTS.md/SOUL.md/USER.md, ghi chú cục bộ, quy tắc persona).
- Thư mục trạng thái (
agentDir) cho hồ sơ xác thực, sổ đăng ký model và cấu hình theo từng agent. - Kho phiên (lịch sử trò chuyện + trạng thái định tuyến) trong
~/.openclaw/agents/<agentId>/sessions.
Hồ sơ xác thực là theo từng agent. Mỗi agent đọc từ tệp riêng của nó:
~/.openclaw/agents/<agentId>/agent/auth-profiles.json
Skills được tải từ workspace của từng agent cùng các gốc dùng chung như ~/.openclaw/skills, rồi được lọc theo danh sách cho phép Skills hiệu dụng của agent khi được cấu hình. Dùng agents.defaults.skills làm nền tảng dùng chung và agents.list[].skills để thay thế theo từng agent. Xem Skills: theo từng agent so với dùng chung và Skills: danh sách cho phép Skills của agent.
Gateway có thể lưu trữ một agent (mặc định) hoặc nhiều agent chạy cạnh nhau.
Đường dẫn (bản đồ nhanh)
- Cấu hình:
~/.openclaw/openclaw.json(hoặcOPENCLAW_CONFIG_PATH) - Thư mục trạng thái:
~/.openclaw(hoặcOPENCLAW_STATE_DIR) - Workspace:
~/.openclaw/workspace(hoặc~/.openclaw/workspace-<agentId>) - Thư mục agent:
~/.openclaw/agents/<agentId>/agent(hoặcagents.list[].agentDir) - Phiên:
~/.openclaw/agents/<agentId>/sessions
Chế độ một agent (mặc định)
Nếu bạn không làm gì, OpenClaw chạy một agent duy nhất:
agentIdmặc định làmain.- Phiên được đặt khóa dạng
agent:main:<mainKey>. - Workspace mặc định là
~/.openclaw/workspace(hoặc~/.openclaw/workspace-<profile>khiOPENCLAW_PROFILEđược đặt). - Trạng thái mặc định là
~/.openclaw/agents/main/agent.
Trình trợ giúp agent
Dùng trình hướng dẫn agent để thêm một agent cô lập mới:
openclaw agents add work
Sau đó thêm bindings (hoặc để trình hướng dẫn làm việc đó) để định tuyến tin nhắn đến.
Xác minh bằng:
openclaw agents list --bindings
Bắt đầu nhanh
Create each agent workspace
Dùng trình hướng dẫn hoặc tạo workspace thủ công:
openclaw agents add coding
openclaw agents add social
Mỗi agent nhận workspace riêng với SOUL.md, AGENTS.md và USER.md tùy chọn, cùng một agentDir chuyên dụng và kho phiên trong ~/.openclaw/agents/<agentId>.
Create channel accounts
Tạo một tài khoản cho mỗi agent trên các kênh bạn chọn:
- Discord: một bot cho mỗi agent, bật Message Content Intent, sao chép từng token.
- Telegram: một bot cho mỗi agent thông qua BotFather, sao chép từng token.
- WhatsApp: liên kết từng số điện thoại theo tài khoản.
openclaw channels login --channel whatsapp --account work
Add agents, accounts, and bindings
Thêm agent trong agents.list, tài khoản kênh trong channels.<channel>.accounts, và kết nối chúng bằng bindings (ví dụ bên dưới).
Restart and verify
openclaw gateway restart
openclaw agents list --bindings
openclaw channels status --probe
Nhiều agent = nhiều người, nhiều tính cách
Với nhiều agent, mỗi agentId trở thành một persona được cô lập hoàn toàn:
- Số điện thoại/tài khoản khác nhau (theo
accountIdcủa từng kênh). - Tính cách khác nhau (các tệp workspace theo từng agent như
AGENTS.mdvàSOUL.md). - Xác thực + phiên riêng biệt (không trao đổi chéo trừ khi được bật rõ ràng).
Điều này cho phép nhiều người dùng chung một máy chủ Gateway trong khi vẫn giữ cho "bộ não" AI và dữ liệu của họ được cô lập.
Tìm kiếm bộ nhớ QMD xuyên agent
Nếu một agent cần tìm kiếm transcript phiên QMD của agent khác, hãy thêm các collection bổ sung trong agents.list[].memorySearch.qmd.extraCollections. Chỉ dùng agents.defaults.memorySearch.qmd.extraCollections khi mọi agent nên kế thừa cùng các collection transcript dùng chung.
{
agents: {
defaults: {
workspace: "~/workspaces/main",
memorySearch: {
qmd: {
extraCollections: [{ path: "~/agents/family/sessions", name: "family-sessions" }],
},
},
},
list: [
{
id: "main",
workspace: "~/workspaces/main",
memorySearch: {
qmd: {
extraCollections: [{ path: "notes" }], // resolves inside workspace -> collection named "notes-main"
},
},
},
{ id: "family", workspace: "~/workspaces/family" },
],
},
memory: {
backend: "qmd",
qmd: { includeDefaultMemory: false },
},
}
Đường dẫn collection bổ sung có thể được dùng chung giữa các agent, nhưng tên collection vẫn tường minh khi đường dẫn nằm ngoài workspace của agent. Đường dẫn bên trong workspace vẫn được phân phạm vi theo agent để mỗi agent giữ bộ tìm kiếm transcript riêng.
Một số WhatsApp, nhiều người (tách DM)
Bạn có thể định tuyến các DM WhatsApp khác nhau đến các agent khác nhau trong khi vẫn dùng một tài khoản WhatsApp. Khớp theo người gửi E.164 (như +15551234567) với peer.kind: "direct". Phản hồi vẫn đến từ cùng số WhatsApp đó (không có danh tính người gửi theo từng agent).
Ví dụ:
{
agents: {
list: [
{ id: "alex", workspace: "~/.openclaw/workspace-alex" },
{ id: "mia", workspace: "~/.openclaw/workspace-mia" },
],
},
bindings: [
{
agentId: "alex",
match: { channel: "whatsapp", peer: { kind: "direct", id: "+15551230001" } },
},
{
agentId: "mia",
match: { channel: "whatsapp", peer: { kind: "direct", id: "+15551230002" } },
},
],
channels: {
whatsapp: {
dmPolicy: "allowlist",
allowFrom: ["+15551230001", "+15551230002"],
},
},
}
Ghi chú:
- Kiểm soát truy cập DM là toàn cục theo tài khoản WhatsApp (ghép nối/danh sách cho phép), không phải theo từng agent.
- Với nhóm dùng chung, hãy bind nhóm vào một agent hoặc dùng Nhóm phát sóng.
Quy tắc định tuyến (cách tin nhắn chọn agent)
Binding là xác định và cụ thể nhất thắng:
peer match
ID DM/nhóm/kênh chính xác.
parentPeer match
Kế thừa luồng.
guildId + roles
Định tuyến theo vai trò Discord.
guildId
Discord.
teamId
Slack.
accountId match for a channel
Dự phòng theo từng tài khoản.
Channel-level match
accountId: "*".
Default agent
Dự phòng về agents.list[].default, nếu không thì mục đầu tiên trong danh sách, mặc định: main.
Tie-breaking and AND semantics
- Nếu nhiều binding khớp trong cùng một tầng, binding đầu tiên theo thứ tự cấu hình sẽ thắng.
- Nếu một binding đặt nhiều trường khớp (ví dụ
peer+guildId), tất cả các trường được chỉ định đều bắt buộc (ngữ nghĩaAND).
Account-scope detail
- Binding bỏ qua
accountIdchỉ khớp với tài khoản mặc định. - Dùng
accountId: "*"làm dự phòng toàn kênh trên mọi tài khoản. - Nếu sau này bạn thêm cùng binding cho cùng agent với một id tài khoản tường minh, OpenClaw nâng cấp binding chỉ theo kênh hiện có thành theo phạm vi tài khoản thay vì nhân đôi nó.
Nhiều tài khoản / số điện thoại
Các kênh hỗ trợ nhiều tài khoản (ví dụ WhatsApp) dùng accountId để nhận diện từng lần đăng nhập. Mỗi accountId có thể được định tuyến đến một agent khác nhau, vì vậy một máy chủ có thể lưu trữ nhiều số điện thoại mà không trộn lẫn phiên.
Nếu bạn muốn có một tài khoản mặc định toàn kênh khi accountId bị bỏ qua, hãy đặt channels.<channel>.defaultAccount (tùy chọn). Khi chưa đặt, OpenClaw sẽ quay về default nếu có, nếu không thì id tài khoản được cấu hình đầu tiên (đã sắp xếp).
Các kênh thường hỗ trợ mẫu này gồm:
whatsapp,telegram,discord,slack,signal,imessageirc,line,googlechat,mattermost,matrix,nextcloud-talkbluebubbles,zalo,zalouser,nostr,feishu
Khái niệm
agentId: một "bộ não" (workspace, xác thực theo từng agent, kho phiên theo từng agent).accountId: một phiên bản tài khoản kênh (ví dụ tài khoản WhatsApp"personal"so với"biz").binding: định tuyến tin nhắn đến vào mộtagentIdtheo(channel, accountId, peer)và tùy chọn id guild/team.- Cuộc trò chuyện trực tiếp thu gọn về
agent:<agentId>:<mainKey>("main" theo từng agent;session.mainKey).
Ví dụ nền tảng
Discord bots per agent
Mỗi tài khoản bot Discord ánh xạ đến một accountId duy nhất. Bind từng tài khoản vào một agent và giữ danh sách cho phép theo từng bot.
{
agents: {
list: [
{ id: "main", workspace: "~/.openclaw/workspace-main" },
{ id: "coding", workspace: "~/.openclaw/workspace-coding" },
],
},
bindings: [
{ agentId: "main", match: { channel: "discord", accountId: "default" } },
{ agentId: "coding", match: { channel: "discord", accountId: "coding" } },
],
channels: {
discord: {
groupPolicy: "allowlist",
accounts: {
default: {
token: "DISCORD_BOT_TOKEN_MAIN",
guilds: {
"123456789012345678": {
channels: {
"222222222222222222": { allow: true, requireMention: false },
},
},
},
},
coding: {
token: "DISCORD_BOT_TOKEN_CODING",
guilds: {
"123456789012345678": {
channels: {
"333333333333333333": { allow: true, requireMention: false },
},
},
},
},
},
},
},
}
- Mời từng bot vào guild và bật Message Content Intent.
- Token nằm trong
channels.discord.accounts.<id>.token(tài khoản mặc định có thể dùngDISCORD_BOT_TOKEN).
Telegram bots per agent
{
agents: {
list: [
{ id: "main", workspace: "~/.openclaw/workspace-main" },
{ id: "alerts", workspace: "~/.openclaw/workspace-alerts" },
],
},
bindings: [
{ agentId: "main", match: { channel: "telegram", accountId: "default" } },
{ agentId: "alerts", match: { channel: "telegram", accountId: "alerts" } },
],
channels: {
telegram: {
accounts: {
default: {
botToken: "123456:ABC...",
dmPolicy: "pairing",
},
alerts: {
botToken: "987654:XYZ...",
dmPolicy: "allowlist",
allowFrom: ["tg:123456789"],
},
},
},
},
}
- Tạo một bot cho mỗi tác nhân bằng BotFather và sao chép từng token.
- Token nằm trong
channels.telegram.accounts.<id>.botToken(tài khoản mặc định có thể dùngTELEGRAM_BOT_TOKEN).
WhatsApp numbers per agent
Liên kết từng tài khoản trước khi khởi động Gateway:
openclaw channels login --channel whatsapp --account personal
openclaw channels login --channel whatsapp --account biz
~/.openclaw/openclaw.json (JSON5):
{
agents: {
list: [
{
id: "home",
default: true,
name: "Home",
workspace: "~/.openclaw/workspace-home",
agentDir: "~/.openclaw/agents/home/agent",
},
{
id: "work",
name: "Work",
workspace: "~/.openclaw/workspace-work",
agentDir: "~/.openclaw/agents/work/agent",
},
],
},
// Deterministic routing: first match wins (most-specific first).
bindings: [
{ agentId: "home", match: { channel: "whatsapp", accountId: "personal" } },
{ agentId: "work", match: { channel: "whatsapp", accountId: "biz" } },
// Optional per-peer override (example: send a specific group to work agent).
{
agentId: "work",
match: {
channel: "whatsapp",
accountId: "personal",
peer: { kind: "group", id: "[email protected]" },
},
},
],
// Off by default: agent-to-agent messaging must be explicitly enabled + allowlisted.
tools: {
agentToAgent: {
enabled: false,
allow: ["home", "work"],
},
},
channels: {
whatsapp: {
accounts: {
personal: {
// Optional override. Default: ~/.openclaw/credentials/whatsapp/personal
// authDir: "~/.openclaw/credentials/whatsapp/personal",
},
biz: {
// Optional override. Default: ~/.openclaw/credentials/whatsapp/biz
// authDir: "~/.openclaw/credentials/whatsapp/biz",
},
},
},
},
}
Các mẫu phổ biến
WhatsApp daily + Telegram deep work
Chia theo kênh: định tuyến WhatsApp đến một tác nhân nhanh dùng hằng ngày và Telegram đến một tác nhân Opus.
{
agents: {
list: [
{
id: "chat",
name: "Everyday",
workspace: "~/.openclaw/workspace-chat",
model: "anthropic/claude-sonnet-4-6",
},
{
id: "opus",
name: "Deep Work",
workspace: "~/.openclaw/workspace-opus",
model: "anthropic/claude-opus-4-6",
},
],
},
bindings: [
{ agentId: "chat", match: { channel: "whatsapp" } },
{ agentId: "opus", match: { channel: "telegram" } },
],
}
Ghi chú:
- Nếu bạn có nhiều tài khoản cho một kênh, hãy thêm
accountIdvào binding (ví dụ{ channel: "whatsapp", accountId: "personal" }). - Để định tuyến một DM/nhóm duy nhất đến Opus trong khi giữ phần còn lại trên chat, hãy thêm binding
match.peercho peer đó; các kết quả khớp peer luôn thắng các quy tắc toàn kênh.
Same channel, one peer to Opus
Giữ WhatsApp trên tác nhân nhanh, nhưng định tuyến một DM đến Opus:
{
agents: {
list: [
{
id: "chat",
name: "Everyday",
workspace: "~/.openclaw/workspace-chat",
model: "anthropic/claude-sonnet-4-6",
},
{
id: "opus",
name: "Deep Work",
workspace: "~/.openclaw/workspace-opus",
model: "anthropic/claude-opus-4-6",
},
],
},
bindings: [
{
agentId: "opus",
match: { channel: "whatsapp", peer: { kind: "direct", id: "+15551234567" } },
},
{ agentId: "chat", match: { channel: "whatsapp" } },
],
}
Binding peer luôn thắng, vì vậy hãy giữ chúng ở trên quy tắc toàn kênh.
Family agent bound to a WhatsApp group
Gắn một tác nhân gia đình chuyên dụng vào một nhóm WhatsApp duy nhất, với cổng kiểm soát bằng lượt nhắc và chính sách công cụ chặt chẽ hơn:
{
agents: {
list: [
{
id: "family",
name: "Family",
workspace: "~/.openclaw/workspace-family",
identity: { name: "Family Bot" },
groupChat: {
mentionPatterns: ["@family", "@familybot", "@Family Bot"],
},
sandbox: {
mode: "all",
scope: "agent",
},
tools: {
allow: [
"exec",
"read",
"sessions_list",
"sessions_history",
"sessions_send",
"sessions_spawn",
"session_status",
],
deny: ["write", "edit", "apply_patch", "browser", "canvas", "nodes", "cron"],
},
},
],
},
bindings: [
{
agentId: "family",
match: {
channel: "whatsapp",
peer: { kind: "group", id: "[email protected]" },
},
},
],
}
Ghi chú:
- Danh sách cho phép/từ chối công cụ là công cụ, không phải Skills. Nếu một skill cần chạy một binary, hãy đảm bảo
execđược cho phép và binary tồn tại trong sandbox. - Để kiểm soát chặt chẽ hơn, hãy đặt
agents.list[].groupChat.mentionPatternsvà giữ allowlist nhóm được bật cho kênh.
Cấu hình sandbox và công cụ theo từng tác nhân
Mỗi tác nhân có thể có sandbox và hạn chế công cụ riêng:
{
agents: {
list: [
{
id: "personal",
workspace: "~/.openclaw/workspace-personal",
sandbox: {
mode: "off", // No sandbox for personal agent
},
// No tool restrictions - all tools available
},
{
id: "family",
workspace: "~/.openclaw/workspace-family",
sandbox: {
mode: "all", // Always sandboxed
scope: "agent", // One container per agent
docker: {
// Optional one-time setup after container creation
setupCommand: "apt-get update && apt-get install -y git curl",
},
},
tools: {
allow: ["read"], // Only read tool
deny: ["exec", "write", "edit", "apply_patch"], // Deny others
},
},
],
},
}
Lợi ích:
- Cô lập bảo mật: hạn chế công cụ cho các tác nhân không đáng tin cậy.
- Kiểm soát tài nguyên: sandbox các tác nhân cụ thể trong khi giữ những tác nhân khác trên host.
- Chính sách linh hoạt: quyền khác nhau cho từng tác nhân.
Xem Sandbox và công cụ đa tác nhân để biết các ví dụ chi tiết.
Liên quan
- Tác nhân ACP — chạy các harness lập trình bên ngoài
- Định tuyến kênh — cách tin nhắn định tuyến đến tác nhân
- Presence — sự hiện diện và trạng thái sẵn sàng của tác nhân
- Session — cô lập và định tuyến phiên
- Tác nhân phụ — tạo các lượt chạy tác nhân nền