OpenClaw có thể chạy CLI AI cục bộ dưới dạng phương án dự phòng chỉ văn bản khi các nhà cung cấp API bị ngừng hoạt động, bị giới hạn tốc độ, hoặc tạm thời hoạt động không đúng. Thiết kế này cố ý thận trọng:Documentation Index
Fetch the complete documentation index at: https://docs2.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
- Các công cụ OpenClaw không được chèn trực tiếp, nhưng các backend có
bundleMcp: truecó thể nhận công cụ gateway qua một cầu nối MCP loopback. - Truyền luồng JSONL cho các CLI hỗ trợ tính năng này.
- Hỗ trợ phiên (để các lượt tiếp theo vẫn mạch lạc).
- Có thể truyền qua hình ảnh nếu CLI chấp nhận đường dẫn hình ảnh.
Khởi động nhanh thân thiện với người mới
Bạn có thể dùng Codex CLI mà không cần cấu hình nào (plugin OpenAI đi kèm đăng ký một backend mặc định):agents.defaults.cliBackends.
Dùng làm phương án dự phòng
Thêm một backend CLI vào danh sách dự phòng để nó chỉ chạy khi các mô hình chính thất bại:- Nếu bạn dùng
agents.defaults.models(danh sách cho phép), bạn cũng phải bao gồm các mô hình backend CLI của mình ở đó. - Nếu nhà cung cấp chính thất bại (xác thực, giới hạn tốc độ, hết thời gian chờ), OpenClaw sẽ thử backend CLI tiếp theo.
Tổng quan cấu hình
Tất cả backend CLI nằm dưới:codex-cli, my-cli).
provider id trở thành vế trái của model ref của bạn:
Ví dụ cấu hình
Cách hoạt động
- Chọn một backend dựa trên tiền tố nhà cung cấp (
codex-cli/...). - Tạo system prompt bằng cùng prompt OpenClaw + ngữ cảnh workspace.
- Thực thi CLI với một session id (nếu được hỗ trợ) để lịch sử luôn nhất quán.
Backend
claude-cliđi kèm giữ một tiến trình Claude stdio sống cho mỗi phiên OpenClaw và gửi các lượt tiếp theo qua stream-json stdin. - Phân tích đầu ra (JSON hoặc văn bản thuần) và trả về văn bản cuối cùng.
- Lưu bền vững session id cho từng backend, để các lượt tiếp theo dùng lại cùng phiên CLI.
Backend Anthropic
claude-cli đi kèm lại được hỗ trợ. Nhân viên Anthropic
đã cho chúng tôi biết rằng việc sử dụng Claude CLI theo kiểu OpenClaw lại được cho phép, vì vậy OpenClaw xem
việc dùng claude -p là được chấp thuận cho tích hợp này trừ khi Anthropic công bố
một chính sách mới.codex-cli đi kèm truyền system prompt của OpenClaw qua
ghi đè cấu hình model_instructions_file của Codex (-c model_instructions_file="..."). Codex không cung cấp cờ kiểu Claude
--append-system-prompt, nên OpenClaw ghi prompt đã lắp ráp vào một
tệp tạm thời cho mỗi phiên Codex CLI mới.
Backend Anthropic claude-cli đi kèm nhận snapshot Skills của OpenClaw
theo hai cách: danh mục Skills OpenClaw gọn trong system prompt được nối thêm, và
một plugin Claude Code tạm thời được truyền bằng --plugin-dir. Plugin chỉ chứa
các Skills đủ điều kiện cho agent/phiên đó, nên bộ phân giải skill gốc của Claude Code
thấy cùng tập đã lọc mà OpenClaw nếu không sẽ quảng bá trong
prompt. Các ghi đè env/API key của skill vẫn được OpenClaw áp dụng cho
môi trường tiến trình con trong lần chạy.
Claude CLI cũng có chế độ quyền không tương tác riêng. OpenClaw ánh xạ chế độ đó
vào chính sách exec hiện có thay vì thêm cấu hình riêng cho Claude: khi
chính sách exec được yêu cầu hiệu lực là YOLO (tools.exec.security: "full" và
tools.exec.ask: "off"), OpenClaw thêm --permission-mode bypassPermissions.
Thiết lập theo agent agents.list[].tools.exec ghi đè tools.exec toàn cục cho
agent đó. Để buộc một chế độ Claude khác, hãy đặt các đối số backend thô rõ ràng
như --permission-mode default hoặc --permission-mode acceptEdits dưới
agents.defaults.cliBackends.claude-cli.args và resumeArgs tương ứng.
Backend Anthropic claude-cli đi kèm cũng ánh xạ các mức /think của OpenClaw
vào cờ --effort gốc của Claude Code cho các mức không phải off. minimal và
low ánh xạ thành low, adaptive và medium ánh xạ thành medium, còn high,
xhigh, và max ánh xạ trực tiếp. Các backend CLI khác cần plugin sở hữu chúng
khai báo một trình ánh xạ argv tương đương trước khi /think có thể ảnh hưởng đến CLI được sinh.
Trước khi OpenClaw có thể dùng backend claude-cli đi kèm, bản thân Claude Code
phải đã đăng nhập trên cùng máy chủ:
agents.defaults.cliBackends.claude-cli.command khi binary claude
chưa có sẵn trên PATH.
Phiên
- Nếu CLI hỗ trợ phiên, đặt
sessionArg(ví dụ--session-id) hoặcsessionArgs(placeholder{sessionId}) khi ID cần được chèn vào nhiều cờ. - Nếu CLI dùng một lệnh con resume với các cờ khác, đặt
resumeArgs(thay thếargskhi tiếp tục) và tùy chọnresumeOutput(cho resume không phải JSON). sessionMode:always: luôn gửi một session id (UUID mới nếu chưa có gì được lưu).existing: chỉ gửi session id nếu trước đó đã có một id được lưu.none: không bao giờ gửi session id.
claude-climặc định làliveSession: "claude-stdio",output: "jsonl", vàinput: "stdin"để các lượt tiếp theo dùng lại tiến trình Claude đang sống trong khi nó còn hoạt động. Warm stdio hiện là mặc định, kể cả với cấu hình tùy chỉnh bỏ qua các trường transport. Nếu Gateway khởi động lại hoặc tiến trình nhàn rỗi thoát, OpenClaw tiếp tục từ session id Claude đã lưu. Các session id đã lưu được xác minh với một bản ghi dự án hiện có có thể đọc được trước khi resume, nên các liên kết ảo bị xóa vớireason=transcript-missingthay vì âm thầm khởi động một phiên Claude CLI mới dưới--resume.- Phiên Claude sống giữ các bộ bảo vệ đầu ra JSONL có giới hạn. Mặc định cho phép tối đa
8 MiB và 20.000 dòng JSONL thô mỗi lượt. Các lượt Claude nhiều công cụ có thể tăng
giới hạn cho từng backend bằng
agents.defaults.cliBackends.claude-cli.reliability.outputLimits.maxTurnRawCharsvàmaxTurnLines; OpenClaw kẹp các thiết lập đó ở 64 MiB và 100.000 dòng. - Phiên CLI đã lưu là tính liên tục do nhà cung cấp sở hữu. Đặt lại phiên hằng ngày ngầm định
không cắt chúng;
/resetvà các chính sáchsession.resetrõ ràng vẫn cắt. - Phiên CLI mới thường chỉ gieo lại từ tóm tắt compaction của OpenClaw
cộng với phần đuôi sau compaction. Để khôi phục các phiên ngắn bị vô hiệu hóa
trước compaction, một backend có thể chọn tham gia bằng
reseedFromRawTranscriptWhenUncompacted: true. OpenClaw vẫn giữ việc gieo lại bản ghi thô có giới hạn và giới hạn nó ở các trường hợp vô hiệu hóa an toàn như thiếu bản ghi CLI, thay đổi system-prompt/MCP, hoặc thử lại do phiên hết hạn; thay đổi hồ sơ xác thực hoặc credential-epoch không bao giờ gieo lại lịch sử bản ghi thô.
serialize: truegiữ các lần chạy cùng làn theo đúng thứ tự.- Hầu hết CLI tuần tự hóa trên một làn nhà cung cấp.
- OpenClaw bỏ dùng lại phiên CLI đã lưu khi danh tính xác thực được chọn thay đổi, bao gồm auth profile id, static API key, static token, hoặc danh tính tài khoản OAuth đã thay đổi khi CLI cung cấp danh tính đó. Luân chuyển access token và refresh token OAuth không cắt phiên CLI đã lưu. Nếu một CLI không cung cấp một OAuth account id ổn định, OpenClaw để CLI đó tự thực thi quyền resume.
Dẫn nhập dự phòng từ các phiên claude-cli
Khi một lần thửclaude-cli chuyển lỗi sang một ứng viên không phải CLI trong
agents.defaults.model.fallbacks, OpenClaw gieo
lần thử tiếp theo bằng một dẫn nhập ngữ cảnh thu hoạch từ bản ghi JSONL cục bộ
của Claude Code tại ~/.claude/projects/. Không có phần gieo này, nhà cung cấp
dự phòng sẽ bắt đầu lạnh vì bản ghi phiên riêng của OpenClaw trống
cho các lần chạy claude-cli.
- Phần dẫn nhập ưu tiên tóm tắt
/compactmới nhất hoặc markercompact_boundary, rồi nối thêm các lượt gần đây nhất sau ranh giới đến một ngân sách ký tự. Các lượt trước ranh giới bị bỏ vì tóm tắt đã đại diện cho chúng. - Các khối công cụ được gộp thành các gợi ý gọn
(tool call: name)và(tool result: …)để giữ ngân sách prompt trung thực. Tóm tắt được gắn nhãn(truncated)nếu vượt giới hạn. - Các dự phòng
claude-clisangclaude-clicùng nhà cung cấp dựa vào--resumeriêng của Claude và bỏ qua phần dẫn nhập. - Phần gieo dùng lại xác thực đường dẫn tệp phiên Claude hiện có, nên không thể đọc đường dẫn tùy ý.
Hình ảnh (truyền qua)
Nếu CLI của bạn chấp nhận đường dẫn hình ảnh, đặtimageArg:
imageArg được đặt, các
đường dẫn đó được truyền làm đối số CLI. Nếu thiếu imageArg, OpenClaw nối thêm
đường dẫn tệp vào prompt (chèn đường dẫn), điều này đủ cho các CLI tự động
tải tệp cục bộ từ đường dẫn thuần.
Đầu vào / đầu ra
output: "json"(mặc định) cố gắng phân tích JSON và trích xuất văn bản + session id.- Với đầu ra JSON của Gemini CLI, OpenClaw đọc văn bản trả lời từ
responsevà mức sử dụng từstatskhi thiếu hoặc trốngusage. output: "jsonl"phân tích các luồng JSONL (ví dụ Codex CLI--json) và trích xuất thông điệp agent cuối cùng cộng với các định danh phiên khi có.output: "text"xem stdout là phản hồi cuối cùng.
input: "arg"(mặc định) truyền prompt làm đối số CLI cuối cùng.input: "stdin"gửi prompt qua stdin.- Nếu prompt rất dài và
maxPromptArgCharsđược đặt, stdin sẽ được dùng.
Mặc định (do plugin sở hữu)
Plugin OpenAI đi kèm cũng đăng ký mặc định chocodex-cli:
command: "codex"args: ["exec","--json","--color","never","--sandbox","workspace-write","--skip-git-repo-check"]resumeArgs: ["exec","resume","{sessionId}","-c","sandbox_mode=\"workspace-write\"","--skip-git-repo-check"]output: "jsonl"resumeOutput: "text"modelArg: "--model"imageArg: "--image"sessionMode: "existing"
google-gemini-cli:
command: "gemini"args: ["--output-format", "json", "--prompt", "{prompt}"]resumeArgs: ["--resume", "{sessionId}", "--output-format", "json", "--prompt", "{prompt}"]imageArg: "@"imagePathScope: "workspace"modelArg: "--model"sessionMode: "existing"sessionIdFields: ["session_id", "sessionId"]
gemini trên PATH (brew install gemini-cli hoặc
npm install -g @google/gemini-cli).
Ghi chú JSON của Gemini CLI:
- Văn bản trả lời được đọc từ trường JSON
response. - Usage dùng dự phòng
statskhiusagevắng mặt hoặc rỗng. stats.cachedđược chuẩn hóa thành OpenClawcacheRead.- Nếu thiếu
stats.input, OpenClaw suy ra token đầu vào từstats.input_tokens - stats.cached.
command).
Mặc định do Plugin sở hữu
Các mặc định backend CLI hiện là một phần của bề mặt Plugin:- Plugin đăng ký chúng bằng
api.registerCliBackend(...). - Backend
idtrở thành tiền tố provider trong model refs. - Cấu hình người dùng trong
agents.defaults.cliBackends.<id>vẫn ghi đè mặc định của Plugin. - Việc dọn dẹp cấu hình riêng cho backend vẫn do Plugin sở hữu thông qua hook
normalizeConfigtùy chọn.
input viết lại system prompt và user prompt được truyền cho CLI. output
viết lại các delta assistant được stream và văn bản cuối cùng đã phân tích trước khi OpenClaw xử lý
các dấu điều khiển và việc gửi qua kênh của riêng nó.
Đối với các CLI phát ra JSONL tương thích Claude Code stream-json, đặt
jsonlDialect: "claude-stream-json" trên cấu hình của backend đó.
Lớp phủ MCP đóng gói
Backend CLI không nhận trực tiếp các lệnh gọi công cụ OpenClaw, nhưng một backend có thể chọn dùng lớp phủ cấu hình MCP được tạo bằngbundleMcp: true.
Hành vi đi kèm hiện tại:
claude-cli: tệp cấu hình MCP nghiêm ngặt được tạocodex-cli: các ghi đè cấu hình nội tuyến chomcp_servers; máy chủ loopback OpenClaw được tạo được đánh dấu bằng chế độ phê duyệt công cụ theo từng máy chủ của Codex để các lệnh gọi MCP không thể bị kẹt ở prompt phê duyệt cục bộgoogle-gemini-cli: tệp cài đặt hệ thống Gemini được tạo
- sinh ra một máy chủ MCP HTTP loopback để phơi bày các công cụ Gateway cho tiến trình CLI
- xác thực bridge bằng token theo từng phiên (
OPENCLAW_MCP_TOKEN) - giới hạn quyền truy cập công cụ theo phiên hiện tại, tài khoản và ngữ cảnh kênh
- tải các máy chủ bundle-MCP đã bật cho workspace hiện tại
- hợp nhất chúng với mọi dạng cấu hình/cài đặt MCP backend hiện có
- viết lại cấu hình khởi chạy bằng chế độ tích hợp do backend sở hữu từ phần mở rộng sở hữu
mcp.sessionIdleTtlMs mili giây nhàn rỗi (mặc định 10
phút; đặt 0 để tắt). Các lần chạy nhúng một lần như thăm dò xác thực,
tạo slug và truy xuất Active Memory yêu cầu dọn dẹp ở cuối lần chạy để các tiến trình con stdio
và stream Streamable HTTP/SSE không tồn tại lâu hơn lần chạy.
Hạn chế
- Không có lệnh gọi công cụ OpenClaw trực tiếp. OpenClaw không chèn lệnh gọi công cụ vào
giao thức backend CLI. Backend chỉ thấy các công cụ Gateway khi chúng chọn dùng
bundleMcp: true. - Streaming tùy thuộc vào backend. Một số backend stream JSONL; những backend khác đệm cho đến khi thoát.
- Đầu ra có cấu trúc phụ thuộc vào định dạng JSON của CLI.
- Phiên Codex CLI tiếp tục qua đầu ra văn bản (không có JSONL), vốn ít
cấu trúc hơn lần chạy
--jsonban đầu. Phiên OpenClaw vẫn hoạt động bình thường.
Khắc phục sự cố
- Không tìm thấy CLI: đặt
commandthành đường dẫn đầy đủ. - Sai tên model: dùng
modelAliasesđể ánh xạprovider/model→ model CLI. - Không có tính liên tục của phiên: bảo đảm
sessionArgđược đặt vàsessionModekhông phải lànone(Codex CLI hiện không thể tiếp tục với đầu ra JSON). - Hình ảnh bị bỏ qua: đặt
imageArg(và xác minh CLI hỗ trợ đường dẫn tệp).