Chuyển đến nội dung chính

Documentation Index

Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt

Use this file to discover all available pages before exploring further.

OpenClaw có thể chạy CLI AI cục bộ như một 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. Điều này được thiết kế có chủ ý theo hướng thận trọng:
  • Các công cụ OpenClaw không được chèn trực tiếp, nhưng các backend có bundleMcp: true có thể nhận công cụ Gateway thông qua một cầu nối MCP loopback.
  • Streaming JSONL cho các CLI hỗ trợ.
  • Hỗ trợ phiên (để các lượt tiếp theo vẫn mạch lạc).
  • Có thể truyền hình ảnh xuyên suốt nếu CLI chấp nhận đường dẫn hình ảnh.
Tính năng này được thiết kế như một mạng an toàn thay vì đường dẫn chính. Dùng nó khi bạn muốn phản hồi văn bản “luôn hoạt động” mà không phụ thuộc vào API bên ngoài. Nếu bạn muốn một runtime harness đầy đủ với điều khiển phiên ACP, tác vụ nền, liên kết luồng/cuộc trò chuyện, và các phiên lập trình bên ngoài bền vững, hãy dùng ACP Agents. Các backend CLI không phải là ACP.

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):
openclaw agent --message "hi" --model codex-cli/gpt-5.5
Nếu Gateway của bạn chạy dưới launchd/systemd và PATH rất tối giản, chỉ cần thêm đường dẫn lệnh:
{
  agents: {
    defaults: {
      cliBackends: {
        "codex-cli": {
          command: "/opt/homebrew/bin/codex",
        },
      },
    },
  },
}
Vậy là xong. Không cần khóa, không cần cấu hình xác thực bổ sung ngoài chính CLI. Nếu bạn dùng một backend CLI đi kèm làm nhà cung cấp tin nhắn chính trên một máy chủ Gateway, OpenClaw hiện tự động tải Plugin đi kèm sở hữu backend đó khi cấu hình của bạn tham chiếu rõ backend đó trong tham chiếu mô hình hoặc dưới agents.defaults.cliBackends.

Dùng làm phương án dự phòng

Thêm backend CLI vào danh sách dự phòng của bạn để nó chỉ chạy khi các mô hình chính thất bại:
{
  agents: {
    defaults: {
      model: {
        primary: "anthropic/claude-opus-4-6",
        fallbacks: ["codex-cli/gpt-5.5"],
      },
      models: {
        "anthropic/claude-opus-4-6": { alias: "Opus" },
        "codex-cli/gpt-5.5": {},
      },
    },
  },
}
Ghi chú:
  • Nếu bạn dùng agents.defaults.models (danh sách cho phép), bạn cũng phải đưa các mô hình backend CLI của mình vào đó.
  • 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:
agents.defaults.cliBackends
Mỗi mục được định khóa bằng một id nhà cung cấp (ví dụ codex-cli, my-cli). Id nhà cung cấp trở thành phía bên trái của tham chiếu mô hình:
<provider>/<model>

Cấu hình ví dụ

{
  agents: {
    defaults: {
      cliBackends: {
        "codex-cli": {
          command: "/opt/homebrew/bin/codex",
        },
        "my-cli": {
          command: "my-cli",
          args: ["--json"],
          output: "json",
          input: "arg",
          modelArg: "--model",
          modelAliases: {
            "claude-opus-4-6": "opus",
            "claude-sonnet-4-6": "sonnet",
          },
          sessionArg: "--session",
          sessionMode: "existing",
          sessionIdFields: ["session_id", "conversation_id"],
          systemPromptArg: "--system",
          // For CLIs with a dedicated prompt-file flag:
          // systemPromptFileArg: "--system-file",
          // Codex-style CLIs can point at a prompt file instead:
          // systemPromptFileConfigArg: "-c",
          // systemPromptFileConfigKey: "model_instructions_file",
          systemPromptWhen: "first",
          imageArg: "--image",
          imageMode: "repeat",
          serialize: true,
        },
      },
    },
  },
}

Cách hoạt động

  1. Chọn một backend dựa trên tiền tố nhà cung cấp (codex-cli/...).
  2. Tạo system prompt bằng cùng prompt OpenClaw + ngữ cảnh workspace.
  3. Thực thi CLI với id phiên (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 stdio Claude sống cho mỗi phiên OpenClaw và gửi các lượt tiếp theo qua stdin stream-json.
  4. 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.
  5. Lưu bền vững id phiên theo 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 cách dùng Claude CLI kiểu OpenClaw lại được cho phép, vì vậy OpenClaw coi 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ố chính sách mới.
Backend OpenAI 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 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: catalog Skills OpenClaw dạng 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 này 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 của lần chạy. Claude CLI cũng có chế độ quyền không tương tác riêng. OpenClaw ánh xạ chế độ đó sang 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"tools.exec.ask: "off"), OpenClaw thêm --permission-mode bypassPermissions. Thiết lập agents.list[].tools.exec theo từng agent ghi đè tools.exec toàn cục cho agent đó. Để ép một chế độ Claude khác, hãy đặt đối số backend thô rõ ràng chẳng hạn --permission-mode default hoặc --permission-mode acceptEdits dưới agents.defaults.cliBackends.claude-cli.argsresumeArgs tương ứng. Trước khi OpenClaw có thể dùng backend claude-cli đi kèm, chính Claude Code phải đã được đăng nhập trên cùng máy chủ:
claude auth login
claude auth status --text
openclaw models auth login --provider anthropic --method cli --set-default
Chỉ dùng agents.defaults.cliBackends.claude-cli.command khi binary claude chưa có trên PATH.

Phiên

  • Nếu CLI hỗ trợ phiên, đặt sessionArg (ví dụ --session-id) hoặc sessionArgs (placeholder {sessionId}) khi ID cần được chèn vào nhiều cờ.
  • Nếu CLI dùng lệnh con tiếp tục với các cờ khác, đặt resumeArgs (thay thế args khi tiếp tục) và tùy chọn resumeOutput (cho các lần tiếp tục không phải JSON).
  • sessionMode:
    • always: luôn gửi id phiên (UUID mới nếu chưa có gì được lưu).
    • existing: chỉ gửi id phiên nếu trước đó đã có một id được lưu.
    • none: không bao giờ gửi id phiên.
  • claude-cli mặ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 khi nó còn hoạt động. Stdio ấm hiện là mặc định, kể cả với cấu hình tùy chỉnh bỏ qua các trường truyền tải. 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ừ id phiên Claude đã lưu. Id phiên đã lưu được xác minh với transcript dự án hiện có có thể đọc trước khi tiếp tục, nên các liên kết ảo được xóa với reason=transcript-missing thay vì âm thầm bắt đầu một phiên Claude CLI mới dưới --resume.
  • Các phiên CLI đã lưu là tính liên tục do nhà cung cấp sở hữu. Việc đặt lại phiên hằng ngày ngầm định không cắt chúng; /reset và các chính sách session.reset rõ ràng vẫn có hiệu lực.
Ghi chú tuần tự hóa:
  • serialize: true giữ các lần chạy cùng lane theo đúng thứ tự.
  • Hầu hết CLI tuần tự hóa trên một lane nhà cung cấp.
  • OpenClaw bỏ việc 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 id hồ sơ xác thực đã đổi, API key tĩnh, token tĩnh, hoặc danh tính tài khoản OAuth khi CLI cung cấp. Việc xoay vòng access token và refresh token OAuth không cắt phiên CLI đã lưu. Nếu CLI không cung cấp một id tài khoản OAuth ổn định, OpenClaw để CLI đó thực thi quyền tiếp tục.

Prelude dự phòng từ các phiên claude-cli

Khi một lần thử claude-cli thất bại và chuyển 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 prelude ngữ cảnh thu hoạch từ transcript JSONL cục bộ của Claude Code tại ~/.claude/projects/. Không có seed này, nhà cung cấp dự phòng sẽ bắt đầu lạnh vì transcript phiên riêng của OpenClaw trống đối với các lần chạy claude-cli.
  • Prelude ưu tiên bản tóm tắt /compact mới nhất hoặc marker compact_boundary, rồi nối thêm các lượt sau ranh giới gần nhất tới một ngân sách ký tự. Các lượt trước ranh giới bị bỏ vì bản tóm tắt đã đại diện cho chúng.
  • Các khối công cụ được gộp thành gợi ý gọn (tool call: name)(tool result: …) để giữ ngân sách prompt trung thực. Bản tóm tắt được gắn nhãn (truncated) nếu vượt giới hạn.
  • Các phương án dự phòng cùng nhà cung cấp từ claude-cli sang claude-cli dựa vào --resume riêng của Claude và bỏ qua prelude.
  • Seed 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 xuyên suốt)

Nếu CLI của bạn chấp nhận đường dẫn hình ảnh, đặt imageArg:
imageArg: "--image",
imageMode: "repeat"
OpenClaw sẽ ghi hình ảnh base64 vào tệp tạm. Nếu 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), đủ 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ố phân tích JSON và trích xuất văn bản + id phiên.
  • Với đầu ra JSON của Gemini CLI, OpenClaw đọc văn bản trả lời từ response và usage từ stats khi usage bị thiếu hoặc trống.
  • output: "jsonl" phân tích các stream JSONL (ví dụ Codex CLI --json) và trích xuất tin nhắn agent cuối cùng cùng các định danh phiên khi có.
  • output: "text" coi stdout là phản hồi cuối cùng.
Chế độ đầu vào:
  • 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 cho codex-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"
Plugin Google đi kèm cũng đăng ký mặc định cho 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"]
Điều kiện tiên quyết: Gemini CLI cục bộ phải được cài đặt và có sẵn dưới dạng gemini trên PATH (brew install gemini-cli hoặc npm install -g @google/gemini-cli). Ghi chú JSON Gemini CLI:
  • Văn bản trả lời được đọc từ trường JSON response.
  • Usage dùng fallback sang stats khi usage không có hoặc trống.
  • stats.cached được chuẩn hóa thành cacheRead của OpenClaw.
  • Nếu thiếu stats.input, OpenClaw suy ra token đầu vào từ stats.input_tokens - stats.cached.
Chỉ ghi đè nếu cần (thường gặp: đường dẫn command tuyệt đối).

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(...).
  • id của backend trở thành tiền tố nhà cung cấp trong tham chiếu mô hình.
  • 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 theo backend vẫn do Plugin sở hữu thông qua hook normalizeConfig tùy chọn.
Các Plugin cần các shim tương thích prompt/tin nhắn rất nhỏ có thể khai báo các phép biến đổi văn bản hai chiều mà không cần thay thế backend của nhà cung cấp hoặc CLI:
api.registerTextTransforms({
  input: [
    { from: /red basket/g, to: "blue basket" },
    { from: /paper ticket/g, to: "digital ticket" },
    { from: /left shelf/g, to: "right shelf" },
  ],
  output: [
    { from: /blue basket/g, to: "red basket" },
    { from: /digital ticket/g, to: "paper ticket" },
    { from: /right shelf/g, to: "left shelf" },
  ],
});
input viết lại prompt hệ thống và prompt người dùng được truyền cho CLI. output viết lại các delta assistant được truyền phát và văn bản cuối đã phân tích trước khi OpenClaw xử lý các marker điều khiển riêng và việc phân phối kênh của nó. Đối với các CLI phát ra JSONL tương thích với Claude Code stream-json, hãy đặt jsonlDialect: "claude-stream-json" trong cấu hình của backend đó.

Gói kèm các lớp phủ MCP

Các 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ằng bundleMcp: true. Hành vi được gói kèm hiện tại:
  • claude-cli: tệp cấu hình MCP nghiêm ngặt được tạo
  • codex-cli: các ghi đè cấu hình nội tuyến cho mcp_servers; máy chủ local 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 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
Khi MCP gói kèm được bật, OpenClaw:
  • sinh ra một máy chủ HTTP MCP loopback để cung cấp các công cụ gateway cho tiến trình CLI
  • xác thực cầu nối bằng token theo phiên (OPENCLAW_MCP_TOKEN)
  • giới hạn quyền truy cập công cụ theo ngữ cảnh phiên, tài khoản và kênh hiện tại
  • 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 hiện có của backend
  • 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ừ extension sở hữu nó
Nếu không có máy chủ MCP nào được bật, OpenClaw vẫn chèn cấu hình nghiêm ngặt khi một backend chọn dùng MCP gói kèm để các lần chạy nền vẫn được cô lập. Các runtime MCP gói kèm theo phạm vi phiên được lưu đệm để tái sử dụng trong một phiên, rồi được thu hồi sau mcp.sessionIdleTtlMs mili giây không hoạt động (mặc định 10 phút; đặt 0 để tắt). Các lần chạy nhúng một lần như dò xác thực, tạo slug và yêu cầu truy hồi Active Memory dọn dẹp khi kết thúc lần chạy để các tiến trình con stdio và luồng Streamable HTTP/SSE không tồn tại lâu hơn lần chạy.

Giới hạn

  • 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. Các backend chỉ thấy công cụ gateway khi chúng chọn dùng bundleMcp: true.
  • Streaming phụ thuộc vào backend. Một số backend truyền phát JSONL; số khác lưu đệ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), nên ít có cấu trúc hơn lần chạy --json ban đầu. Các 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 command thành đường dẫn đầy đủ.
  • Tên model sai: dùng modelAliases để ánh xạ provider/model → model CLI.
  • Không có tính liên tục của phiên: đảm bảo sessionArg được đặt và sessionMode không phải là none (Codex CLI hiện chưa 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).

Liên quan