diff --git a/docs/zh-CN/cli/gateway.md b/docs/zh-CN/cli/gateway.md
index ab2a82ee0..be7414caf 100644
--- a/docs/zh-CN/cli/gateway.md
+++ b/docs/zh-CN/cli/gateway.md
@@ -4,28 +4,28 @@ read_when:
- 调试 Gateway 网关认证、绑定模式和连接性
- 通过 Bonjour 发现 Gateway 网关(本地 + 广域 DNS-SD)
sidebarTitle: Gateway
-summary: OpenClaw Gateway 网关 CLI(`openclaw gateway`)—— 运行、查询和发现 Gateway 网关
+summary: OpenClaw Gateway 网关 CLI(`openclaw gateway`)— 运行、查询和发现 Gateway 网关
title: Gateway 网关
x-i18n:
- generated_at: "2026-04-26T09:05:37Z"
+ generated_at: "2026-04-27T02:43:47Z"
model: gpt-5.4
provider: openai
- source_hash: c8cdca95676f0b098e2dd79ff4245a32eaae82711ed6c2b7e39522331872cfd9
+ source_hash: 0f26cf45f31d4b5987c7158af7d7935d443875e88413e691e4ad39fbb35cdc60
source_path: cli/gateway.md
workflow: 15
---
-Gateway 网关是 OpenClaw 的 WebSocket 服务器(渠道、节点、会话、钩子)。本页中的子命令都位于 `openclaw gateway …` 下。
+Gateway 网关是 OpenClaw 的 WebSocket 服务器(渠道、节点、会话、钩子)。本页中的子命令位于 `openclaw gateway …` 之下。
本地 mDNS + 广域 DNS-SD 设置。
- OpenClaw 如何通告并发现 Gateway 网关。
+ OpenClaw 如何通告并查找 Gateway 网关。
- 顶层 gateway 配置键名。
+ 顶层 Gateway 网关配置键。
@@ -45,12 +45,12 @@ openclaw gateway run
- - 默认情况下,除非在 `~/.openclaw/openclaw.json` 中设置了 `gateway.mode=local`,否则 Gateway 网关会拒绝启动。对于临时 / 开发运行,可使用 `--allow-unconfigured`。
- - `openclaw onboard --mode local` 和 `openclaw setup` 预期会写入 `gateway.mode=local`。如果文件存在但缺少 `gateway.mode`,应将其视为损坏或被覆盖的配置,并进行修复,而不是隐式假定为 local 模式。
+ - 默认情况下,除非在 `~/.openclaw/openclaw.json` 中设置了 `gateway.mode=local`,否则 Gateway 网关会拒绝启动。对于临时/开发运行,请使用 `--allow-unconfigured`。
+ - 预期 `openclaw onboard --mode local` 和 `openclaw setup` 会写入 `gateway.mode=local`。如果文件存在但缺少 `gateway.mode`,应将其视为已损坏或被覆盖的配置,并修复它,而不是隐式假定为 local 模式。
- 如果文件存在且缺少 `gateway.mode`,Gateway 网关会将其视为可疑的配置损坏,并拒绝为你“猜测为 local”。
- 未启用认证时,禁止绑定到 loopback 之外的地址(安全护栏)。
- - 在获得授权时,`SIGUSR1` 会触发进程内重启(默认启用 `commands.restart`;将 `commands.restart: false` 设为 false 可阻止手动重启,但 gateway 工具 / 配置 apply / update 仍然允许)。
- - `SIGINT` / `SIGTERM` 处理程序会停止 gateway 进程,但不会恢复任何自定义终端状态。如果你用 TUI 或 raw-mode 输入封装了 CLI,请在退出前恢复终端。
+ - 在授权的情况下,`SIGUSR1` 会触发进程内重启(默认启用 `commands.restart`;设置 `commands.restart: false` 可阻止手动重启,而 gateway 工具 / 配置 apply/update 仍然允许)。
+ - `SIGINT`/`SIGTERM` 处理程序会停止 gateway 进程,但不会恢复任何自定义终端状态。如果你使用 TUI 或 raw-mode 输入包装 CLI,请在退出前恢复终端状态。
@@ -66,7 +66,7 @@ openclaw gateway run
认证模式覆盖。
- Token 覆盖(也会为该进程设置 `OPENCLAW_GATEWAY_TOKEN`)。
+ 令牌覆盖(也会为进程设置 `OPENCLAW_GATEWAY_TOKEN`)。
密码覆盖。
@@ -78,25 +78,25 @@ openclaw gateway run
通过 Tailscale 暴露 Gateway 网关。
- 在关闭时重置 Tailscale serve / funnel 配置。
+ 关闭时重置 Tailscale serve/funnel 配置。
- 允许在配置中没有 `gateway.mode=local` 的情况下启动 gateway。仅绕过用于临时 / 开发引导的启动保护;不会写入或修复配置文件。
+ 允许在配置中没有 `gateway.mode=local` 的情况下启动 gateway。仅绕过临时 / 开发引导的启动保护;不会写入或修复配置文件。
- 如果缺失,则创建开发配置 + 工作区(跳过 `BOOTSTRAP.md`)。
+ 如果缺失,则创建开发配置 + 工作区(跳过 BOOTSTRAP.md)。
重置开发配置 + 凭证 + 会话 + 工作区(需要 `--dev`)。
- 启动前终止所选端口上的任何现有监听器。
+ 启动前终止所选端口上任何现有的监听器。
详细日志。
- 仅在控制台中显示 CLI 后端日志(并启用 stdout / stderr)。
+ 仅在控制台中显示 CLI 后端日志(并启用 stdout/stderr)。
WebSocket 日志样式。
@@ -112,13 +112,13 @@ openclaw gateway run
-内联 `--password` 可能会在本地进程列表中暴露。优先使用 `--password-file`、环境变量或由 SecretRef 支持的 `gateway.auth.password`。
+内联 `--password` 可能会暴露在本地进程列表中。优先使用 `--password-file`、环境变量,或由 SecretRef 支持的 `gateway.auth.password`。
-### 启动分析
+### 启动性能分析
-- 设置 `OPENCLAW_GATEWAY_STARTUP_TRACE=1`,以在 Gateway 网关启动期间记录各阶段耗时。
-- 运行 `pnpm test:startup:gateway -- --runs 5 --warmup 1` 以对 Gateway 网关启动进行基准测试。该基准测试会记录首个进程输出、`/healthz`、`/readyz` 和启动跟踪耗时。
+- 设置 `OPENCLAW_GATEWAY_STARTUP_TRACE=1` 以在 Gateway 网关启动期间记录各阶段耗时。
+- 运行 `pnpm test:startup:gateway -- --runs 5 --warmup 1` 以对 Gateway 网关启动进行基准测试。该基准测试会记录首个进程输出、`/healthz`、`/readyz` 以及启动跟踪耗时。
## 查询正在运行的 Gateway 网关
@@ -126,13 +126,13 @@ openclaw gateway run
- - 默认:人类可读(在 TTY 中带颜色)。
- - `--json`:机器可读 JSON(无样式 / 无 spinner)。
+ - 默认:适合人类阅读(在 TTY 中带颜色)。
+ - `--json`:适合机器读取的 JSON(无样式 / 无 spinner)。
- `--no-color`(或 `NO_COLOR=1`):禁用 ANSI,同时保留人类可读布局。
- `--url `:Gateway 网关 WebSocket URL。
- - `--token `:Gateway 网关 token。
+ - `--token `:Gateway 网关令牌。
- `--password `:Gateway 网关密码。
- `--timeout `:超时 / 预算(因命令而异)。
- `--expect-final`:等待“final”响应(智能体调用)。
@@ -149,11 +149,11 @@ openclaw gateway run
openclaw gateway health --url ws://127.0.0.1:18789
```
-HTTP `/healthz` 端点是存活探针:一旦服务器可以响应 HTTP,它就会返回。HTTP `/readyz` 端点更严格;当启动 sidecar、渠道或已配置的钩子仍在稳定过程中时,它会保持为红色状态。
+HTTP `/healthz` 端点是存活探针:一旦服务器能够响应 HTTP,它就会返回。HTTP `/readyz` 端点更严格;在启动 sidecar、渠道或已配置的钩子仍在稳定期间,它会持续显示为未就绪。
### `gateway usage-cost`
-从会话日志中获取 usage-cost 汇总。
+从会话日志获取 usage-cost 汇总。
```bash
openclaw gateway usage-cost
@@ -167,7 +167,7 @@ openclaw gateway usage-cost --json
### `gateway stability`
-从正在运行的 Gateway 网关中获取最近的诊断稳定性记录器。
+从正在运行的 Gateway 网关获取最近的诊断稳定性记录器数据。
```bash
openclaw gateway stability
@@ -178,7 +178,7 @@ openclaw gateway stability --json
```
- 要包含的最近事件最大数量(最大为 `1000`)。
+ 要包含的最近事件的最大数量(最大为 `1000`)。
按诊断事件类型筛选,例如 `payload.large` 或 `diagnostic.memory.pressure`。
@@ -187,10 +187,10 @@ openclaw gateway stability --json
仅包含某个诊断序列号之后的事件。
- 读取持久化的稳定性 bundle,而不是调用正在运行的 Gateway 网关。使用 `--bundle latest`(或仅使用 `--bundle`)可读取状态目录下最新的 bundle,或者直接传入 bundle JSON 路径。
+ 读取持久化的稳定性 bundle,而不是调用正在运行的 Gateway 网关。对状态目录下最新的 bundle 使用 `--bundle latest`(或仅使用 `--bundle`),或者直接传入 bundle JSON 路径。
- 写出可共享的支持诊断 zip,而不是打印稳定性详情。
+ 写入可共享的支持诊断 zip,而不是打印稳定性详情。
`--export` 的输出路径。
@@ -198,14 +198,14 @@ openclaw gateway stability --json
- - 记录会保留运维元数据:事件名称、计数、字节大小、内存读数、队列 / 会话状态、渠道 / 插件名称以及已脱敏的会话摘要。它们不会保留聊天文本、webhook 正文、工具输出、原始请求或响应正文、token、cookie、密钥值、主机名或原始会话 id。设置 `diagnostics.enabled: false` 可完全禁用记录器。
- - 在 Gateway 网关发生致命退出、关闭超时和重启启动失败时,如果记录器中有事件,OpenClaw 会将同样的诊断快照写入 `~/.openclaw/logs/stability/openclaw-stability-*.json`。你可以使用 `openclaw gateway stability --bundle latest` 检查最新 bundle;`--limit`、`--type` 和 `--since-seq` 也适用于 bundle 输出。
+ - 记录会保留运维元数据:事件名称、计数、字节大小、内存读数、队列 / 会话状态、渠道 / 插件名称,以及已脱敏的会话摘要。它们不会保留聊天文本、webhook 正文、工具输出、原始请求或响应正文、令牌、cookie、密钥值、主机名或原始会话 ID。设置 `diagnostics.enabled: false` 可完全禁用记录器。
+ - 在 Gateway 网关致命退出、关闭超时和重启启动失败时,如果记录器中有事件,OpenClaw 会将相同的诊断快照写入 `~/.openclaw/logs/stability/openclaw-stability-*.json`。使用 `openclaw gateway stability --bundle latest` 可检查最新 bundle;`--limit`、`--type` 和 `--since-seq` 同样适用于 bundle 输出。
### `gateway diagnostics export`
-写出一个本地诊断 zip,专门用于附加到 bug 报告。有关隐私模型和 bundle 内容,请参见 [诊断导出](/zh-CN/gateway/diagnostics)。
+写入一个本地诊断 zip,旨在附加到错误报告中。有关隐私模型和 bundle 内容,请参阅 [诊断导出](/zh-CN/gateway/diagnostics)。
```bash
openclaw gateway diagnostics export
@@ -214,40 +214,40 @@ openclaw gateway diagnostics export --json
```
- 输出 zip 路径。默认输出到状态目录下的支持导出文件。
+ 输出 zip 路径。默认为状态目录下的支持导出文件。
- 要包含的已脱敏日志行最大数量。
+ 要包含的最大已脱敏日志行数。
- 要检查的日志字节最大数量。
+ 要检查的最大日志字节数。
用于健康快照的 Gateway 网关 WebSocket URL。
- 用于健康快照的 Gateway 网关 token。
+ 用于健康快照的 Gateway 网关令牌。
用于健康快照的 Gateway 网关密码。
- Status / health 快照超时。
+ Status / 健康快照超时。
跳过持久化稳定性 bundle 查找。
- 以 JSON 形式打印写入路径、大小和清单。
+ 以 JSON 打印已写入的路径、大小和清单。
-该导出包含清单、Markdown 摘要、配置形状、已脱敏配置详情、已脱敏日志摘要、已脱敏 Gateway 网关 status / health 快照,以及存在时的最新稳定性 bundle。
+该导出包含清单、Markdown 摘要、配置结构、已脱敏的配置详情、已脱敏的日志摘要、已脱敏的 Gateway 网关 Status / 健康快照,以及存在时的最新稳定性 bundle。
-它旨在被共享。它会保留有助于调试的运维细节,例如安全的 OpenClaw 日志字段、子系统名称、状态码、持续时间、已配置模式、端口、插件 id、provider id、非机密功能设置以及已脱敏的运维日志消息。它会省略或脱敏聊天文本、webhook 正文、工具输出、凭证、cookie、账户 / 消息标识符、提示词 / 指令文本、主机名和密钥值。当某条 LogTape 风格消息看起来像用户 / 聊天 / 工具负载文本时,导出只会保留该消息已被省略以及它的字节数。
+它旨在被共享。它会保留有助于调试的运维细节,例如安全的 OpenClaw 日志字段、子系统名称、状态码、耗时、已配置模式、端口、插件 ID、提供商 ID、非敏感功能设置,以及已脱敏的运维日志消息。它会省略或脱敏聊天文本、webhook 正文、工具输出、凭证、cookie、账户 / 消息标识符、提示 / 指令文本、主机名和密钥值。当一条 LogTape 风格的消息看起来像用户 / 聊天 / 工具负载文本时,导出只会保留该消息已被省略以及其字节数。
### `gateway status`
-`gateway status` 会显示 Gateway 网关服务(launchd / systemd / schtasks),以及对连接性 / 认证能力的可选探测。
+`gateway status` 会显示 Gateway 网关服务(launchd/systemd/schtasks),以及一个可选的连接性 / 认证能力探测。
```bash
openclaw gateway status
@@ -256,10 +256,10 @@ openclaw gateway status --require-rpc
```
- 添加显式探测目标。仍会探测已配置的远程端点和 localhost。
+ 添加一个显式探测目标。仍会探测已配置的远程地址 + localhost。
- 用于探测的 token 认证。
+ 用于探测的令牌认证。
用于探测的密码认证。
@@ -274,25 +274,25 @@ openclaw gateway status --require-rpc
也扫描系统级服务。
- 将默认连接性探测升级为读探测,并在该读探测失败时以非零状态退出。不能与 `--no-probe` 组合使用。
+ 将默认的连接性探测升级为读取探测,并在该读取探测失败时以非零状态退出。不能与 `--no-probe` 组合使用。
- 即使本地 CLI 配置缺失或无效,`gateway status` 仍可用于诊断。
- - 默认的 `gateway status` 会证明服务状态、WebSocket 连接以及握手时可见的认证能力。它不会证明读 / 写 / 管理操作。
- - 对于首次设备认证,诊断探测是非变更性的:如果已有缓存的设备 token,它会复用该 token,但不会仅为了检查 status 而创建新的 CLI 设备身份或只读设备配对记录。
- - `gateway status` 会在可能的情况下解析已配置的认证 SecretRef 以用于探测认证。
- - 如果在此命令路径中所需的认证 SecretRef 无法解析,且探测连接 / 认证失败,`gateway status --json` 会报告 `rpc.authWarning`;请显式传递 `--token` / `--password`,或先解析密钥来源。
- - 如果探测成功,则会抑制未解析 auth-ref 的警告,以避免误报。
- - 当仅有正在监听的服务还不够、并且你还需要读范围 RPC 调用也保持健康时,请在脚本和自动化中使用 `--require-rpc`。
- - `--deep` 会尽力扫描额外的 launchd / systemd / schtasks 安装。当检测到多个类似 gateway 的服务时,人类可读输出会打印清理提示,并警告大多数设置应为每台机器运行一个 gateway。
- - 人类可读输出包含已解析的文件日志路径,以及 CLI 与服务配置路径 / 有效性快照,以帮助诊断 profile 或状态目录漂移。
+ - 默认的 `gateway status` 可证明服务状态、WebSocket 连接以及握手时可见的认证能力。它不证明读 / 写 / 管理操作。
+ - 对于首次设备认证,诊断探测不会产生变更:如果已有缓存的设备令牌,则会复用它,但不会仅为了检查状态而创建新的 CLI 设备身份或只读设备配对记录。
+ - 在可能的情况下,`gateway status` 会为探测认证解析已配置的认证 SecretRef。
+ - 如果在此命令路径中所需的认证 SecretRef 无法解析,且探测连接 / 认证失败,则 `gateway status --json` 会报告 `rpc.authWarning`;请显式传递 `--token`/`--password`,或先解析密钥来源。
+ - 如果探测成功,则会抑制未解析 auth-ref 警告,以避免误报。
+ - 当仅有一个正在监听的服务还不够,而你还需要具备读取范围的 RPC 调用也保持健康时,请在脚本和自动化中使用 `--require-rpc`。
+ - `--deep` 会尽力扫描额外的 launchd/systemd/schtasks 安装项。当检测到多个类似 gateway 的服务时,人类可读输出会打印清理提示,并警告大多数设置应当每台机器仅运行一个 gateway。
+ - 人类可读输出包含解析后的文件日志路径,以及 CLI 与服务的配置路径 / 有效性快照,以帮助诊断 profile 或状态目录漂移。
- - 在 Linux systemd 安装中,服务认证漂移检查会同时读取 unit 中的 `Environment=` 和 `EnvironmentFile=` 值(包括 `%h`、带引号路径、多个文件以及可选的 `-` 文件)。
+ - 在 Linux systemd 安装中,服务认证漂移检查会同时读取单元中的 `Environment=` 和 `EnvironmentFile=` 值(包括 `%h`、带引号的路径、多个文件以及可选的 `-` 文件)。
- 漂移检查会使用合并后的运行时环境变量解析 `gateway.auth.token` SecretRef(优先使用服务命令环境变量,其次回退到进程环境变量)。
- - 如果 token 认证实际上未激活(显式 `gateway.auth.mode` 为 `password` / `none` / `trusted-proxy`,或者 mode 未设置且 password 可能生效,同时没有任何 token 候选可生效),则 token 漂移检查会跳过配置 token 解析。
+ - 如果令牌认证实际上未启用(显式的 `gateway.auth.mode` 为 `password`/`none`/`trusted-proxy`,或 mode 未设置且 password 可能胜出并且不存在可能胜出的 token 候选值),则 token 漂移检查会跳过配置 token 解析。
@@ -301,16 +301,16 @@ openclaw gateway status --require-rpc
`gateway probe` 是“调试一切”的命令。它始终会探测:
- 你配置的远程 gateway(如果已设置),以及
-- localhost(loopback),**即使已配置远程端点也是如此**。
+- localhost(loopback),**即使已配置远程地址也是如此**。
-如果你传递 `--url`,则该显式目标会被添加到这两者之前。人类可读输出会将目标标记为:
+如果你传递 `--url`,该显式目标会被添加到这两者之前。人类可读输出会将目标标记为:
-- `URL (explicit)`
-- `Remote (configured)` 或 `Remote (configured, inactive)`
+- `URL(显式)`
+- `Remote(已配置)` 或 `Remote(已配置,未激活)`
- `Local loopback`
-如果可到达多个 gateway,它会全部打印出来。当你使用隔离的 profile / 端口(例如救援 bot)时,支持多个 gateway,但大多数安装仍然只运行单个 gateway。
+如果有多个 gateway 可达,它会打印全部。使用隔离的 profile / 端口时支持多个 gateway(例如 rescue bot),但大多数安装仍然只运行单个 gateway。
```bash
@@ -319,51 +319,51 @@ openclaw gateway probe --json
```
-
+
- `Reachable: yes` 表示至少有一个目标接受了 WebSocket 连接。
- - `Capability: read-only|write-capable|admin-capable|pairing-pending|connect-only` 报告探测能够证明的认证能力。它与可达性是分开的。
- - `Read probe: ok` 表示读范围详情 RPC 调用(`health` / `status` / `system-presence` / `config.get`)也成功了。
- - `Read probe: limited - missing scope: operator.read` 表示连接成功,但读范围 RPC 受到限制。这会被报告为**降级**可达性,而不是完全失败。
+ - `Capability: read-only|write-capable|admin-capable|pairing-pending|connect-only` 表示探测能够证明的认证能力。它独立于可达性。
+ - `Read probe: ok` 表示读取范围的详细 RPC 调用(`health`/`status`/`system-presence`/`config.get`)也已成功。
+ - `Read probe: limited - missing scope: operator.read` 表示连接成功,但读取范围的 RPC 受限。这会被报告为**降级**可达性,而不是完全失败。
- 与 `gateway status` 一样,probe 会复用现有缓存的设备认证,但不会创建首次设备身份或配对状态。
- - 只有当所有被探测目标都不可达时,退出码才会为非零。
+ - 只有在所有已探测目标均不可达时,退出码才为非零。
顶层:
- `ok`:至少有一个目标可达。
- - `degraded`:至少有一个目标的详情 RPC 因范围受限。
- - `capability`:在所有可达目标中观察到的最佳能力(`read_only`、`write_capable`、`admin_capable`、`pairing_pending`、`connected_no_operator_scope` 或 `unknown`)。
- - `primaryTargetId`:按以下顺序应视为当前活动胜出的最佳目标:显式 URL、SSH 隧道、已配置远程端点,然后是本地 loopback。
+ - `degraded`:至少有一个目标的详细 RPC 受作用域限制。
+ - `capability`:所有可达目标中检测到的最佳能力(`read_only`、`write_capable`、`admin_capable`、`pairing_pending`、`connected_no_operator_scope` 或 `unknown`)。
+ - `primaryTargetId`:按以下顺序应视为活动优胜者的最佳目标:显式 URL、SSH 隧道、已配置远程地址,然后是本地 loopback。
- `warnings[]`:尽力而为的警告记录,包含 `code`、`message` 和可选的 `targetIds`。
- - `network`:根据当前配置和主机网络推导出的本地 loopback / tailnet URL 提示。
- - `discovery.timeoutMs` 和 `discovery.count`:本次 probe 使用的实际发现预算 / 结果数量。
+ - `network`:根据当前配置和主机网络派生出的本地 loopback/tailnet URL 提示。
+ - `discovery.timeoutMs` 和 `discovery.count`:此轮 probe 实际使用的设备发现预算 / 结果数量。
每个目标(`targets[].connect`):
- - `ok`:连接后并结合降级分类得到的可达性。
- - `rpcOk`:完整详情 RPC 成功。
- - `scopeLimited`:详情 RPC 因缺少 operator 范围而失败。
+ - `ok`:连接后并经过降级分类后的可达性。
+ - `rpcOk`:完整详细 RPC 成功。
+ - `scopeLimited`:详细 RPC 因缺少 operator 作用域而失败。
每个目标(`targets[].auth`):
- - `role`:在可用时,由 `hello-ok` 报告的认证角色。
- - `scopes`:在可用时,由 `hello-ok` 报告的已授予范围。
- - `capability`:为该目标呈现的认证能力分类。
+ - `role`:可用时,在 `hello-ok` 中报告的认证角色。
+ - `scopes`:可用时,在 `hello-ok` 中报告的已授予作用域。
+ - `capability`:该目标呈现出的认证能力分类。
- - `ssh_tunnel_failed`:SSH 隧道设置失败;命令已回退为直接探测。
- - `multiple_gateways`:有多个目标可达;除非你有意运行隔离 profile(例如救援 bot),否则这并不常见。
- - `auth_secretref_unresolved`:某个失败目标的已配置认证 SecretRef 无法解析。
- - `probe_scope_limited`:WebSocket 连接成功,但读探测因缺少 `operator.read` 而受限。
+ - `ssh_tunnel_failed`:SSH 隧道建立失败;命令已回退为直接探测。
+ - `multiple_gateways`:有多个目标可达;除非你有意运行隔离的 profile(例如 rescue bot),否则这并不常见。
+ - `auth_secretref_unresolved`:某个已配置的认证 SecretRef 无法为失败目标解析。
+ - `probe_scope_limited`:WebSocket 连接成功,但读取探测因缺少 `operator.read` 而受限。
-#### 通过 SSH 连接远程端点(与 Mac 应用一致)
+#### 通过 SSH 连接远程地址(与 Mac 应用一致)
-macOS 应用的“Remote over SSH”模式使用本地端口转发,使远程 gateway(它可能仅绑定到 loopback)可以通过 `ws://127.0.0.1:` 访问。
+macOS 应用中的“Remote over SSH”模式使用本地端口转发,使远程 gateway(可能仅绑定到 loopback)可通过 `ws://127.0.0.1:` 访问。
-CLI 等价命令:
+等效 CLI:
```bash
openclaw gateway probe --ssh user@gateway-host
@@ -376,7 +376,7 @@ openclaw gateway probe --ssh user@gateway-host
身份文件。
- 从已解析的发现端点(`local.` 加上已配置的广域域名(如果有))中选择首个发现的 gateway 主机作为 SSH 目标。会忽略仅 TXT 的提示。
+ 从已解析的设备发现端点(`local.` 加上已配置的广域域名,如果有)中选择第一个发现的 gateway 主机作为 SSH 目标。纯 TXT 提示会被忽略。
配置(可选,用作默认值):
@@ -386,7 +386,7 @@ openclaw gateway probe --ssh user@gateway-host
### `gateway call `
-底层 RPC 辅助工具。
+底层 RPC 辅助命令。
```bash
openclaw gateway call status
@@ -400,7 +400,7 @@ openclaw gateway call logs.tail --params '{"sinceMs": 60000}'
Gateway 网关 WebSocket URL。
- Gateway 网关 token。
+ Gateway 网关令牌。
Gateway 网关密码。
@@ -412,7 +412,7 @@ openclaw gateway call logs.tail --params '{"sinceMs": 60000}'
主要用于智能体风格的 RPC,这类 RPC 会在最终负载之前流式传输中间事件。
- 机器可读 JSON 输出。
+ 适合机器读取的 JSON 输出。
@@ -429,21 +429,57 @@ openclaw gateway restart
openclaw gateway uninstall
```
+### 使用 wrapper 安装
+
+当受管服务必须通过另一个可执行文件启动时,请使用 `--wrapper`,例如
+密钥管理器 shim 或 run-as helper。wrapper 会接收正常的 Gateway 网关参数,并
+负责最终使用这些参数执行 `openclaw` 或 Node。
+
+```bash
+cat > ~/.local/bin/openclaw-doppler <<'EOF'
+#!/usr/bin/env bash
+set -euo pipefail
+exec doppler run --project my-project --config production -- openclaw "$@"
+EOF
+chmod +x ~/.local/bin/openclaw-doppler
+
+openclaw gateway install --wrapper ~/.local/bin/openclaw-doppler --force
+openclaw gateway restart
+```
+
+你也可以通过环境变量设置 wrapper。`gateway install` 会验证该路径是否为
+可执行文件,将 wrapper 写入服务的 `ProgramArguments`,并在服务环境中持久化
+`OPENCLAW_WRAPPER`,以供后续强制重装、更新和 Doctor 修复使用。
+
+```bash
+OPENCLAW_WRAPPER="$HOME/.local/bin/openclaw-doppler" openclaw gateway install --force
+openclaw doctor
+```
+
+要移除已持久化的 wrapper,请在重新安装时清空 `OPENCLAW_WRAPPER`:
+
+```bash
+OPENCLAW_WRAPPER= openclaw gateway install --force
+openclaw gateway restart
+```
+
- `gateway status`:`--url`、`--token`、`--password`、`--timeout`、`--no-probe`、`--require-rpc`、`--deep`、`--json`
- - `gateway install`:`--port`、`--runtime `、`--token`、`--force`、`--json`
+ - `gateway install`:`--port`、`--runtime `、`--token`、`--wrapper `、`--force`、`--json`
- `gateway uninstall|start|stop|restart`:`--json`
- - `gateway install` 支持 `--port`、`--runtime`、`--token`、`--force`、`--json`。
- - 使用 `gateway restart` 重启受管服务。不要把 `gateway stop` 和 `gateway start` 串起来代替重启;在 macOS 上,`gateway stop` 会在停止前故意禁用 LaunchAgent。
- - 当 token 认证需要 token 且 `gateway.auth.token` 由 SecretRef 管理时,`gateway install` 会验证该 SecretRef 可解析,但不会将解析后的 token 持久化到服务环境元数据中。
- - 如果 token 认证需要 token 且已配置的 token SecretRef 无法解析,安装会以关闭失败方式终止,而不是持久化回退明文。
- - 对于 `gateway run` 的密码认证,相比内联 `--password`,优先使用 `OPENCLAW_GATEWAY_PASSWORD`、`--password-file` 或由 SecretRef 支持的 `gateway.auth.password`。
- - 在推断认证模式下,仅 shell 中的 `OPENCLAW_GATEWAY_PASSWORD` 不会放宽安装时对 token 的要求;安装受管服务时,请使用持久配置(`gateway.auth.password` 或配置 `env`)。
- - 如果同时配置了 `gateway.auth.token` 和 `gateway.auth.password`,且未设置 `gateway.auth.mode`,则安装会被阻止,直到显式设置 mode。
- - 生命周期命令接受 `--json` 以供脚本使用。
+ - `gateway install` 支持 `--port`、`--runtime`、`--token`、`--wrapper`、`--force`、`--json`。
+ - `--wrapper ` 会让受管服务通过一个可执行 wrapper 启动,将 `ProgramArguments` 写为 ` gateway --port ...`,并在服务环境中持久化 `OPENCLAW_WRAPPER`,这样强制重装、更新和 Doctor 修复会继续使用相同的 wrapper。`openclaw doctor` 也会报告当前启用的 wrapper。如果省略 `--wrapper`,安装会遵循 shell 或当前服务环境中已有的 `OPENCLAW_WRAPPER`。
+ - 要移除已持久化的 wrapper,请使用空 wrapper 环境重新安装,例如 `OPENCLAW_WRAPPER= openclaw gateway install --force`。
+ - 使用 `gateway restart` 重启受管服务。不要把 `gateway stop` 和 `gateway start` 串联起来作为重启替代;在 macOS 上,`gateway stop` 会先有意禁用 LaunchAgent,然后再停止它。
+ - 当 token 认证需要 token 且 `gateway.auth.token` 由 SecretRef 管理时,`gateway install` 会验证该 SecretRef 可被解析,但不会将解析后的 token 持久化到服务环境元数据中。
+ - 如果 token 认证需要 token,而已配置的 token SecretRef 无法解析,则安装会以安全关闭方式失败,而不是持久化回退的明文值。
+ - 对于 `gateway run` 的密码认证,优先使用 `OPENCLAW_GATEWAY_PASSWORD`、`--password-file` 或由 SecretRef 支持的 `gateway.auth.password`,而不是内联 `--password`。
+ - 在推断认证模式下,仅 shell 中的 `OPENCLAW_GATEWAY_PASSWORD` 不会放宽安装时的 token 要求;安装受管服务时,请使用持久配置(`gateway.auth.password` 或配置 `env`)。
+ - 如果同时配置了 `gateway.auth.token` 和 `gateway.auth.password`,而 `gateway.auth.mode` 未设置,则在显式设置 mode 之前会阻止安装。
+ - 生命周期命令接受 `--json` 以便脚本化使用。
@@ -451,19 +487,19 @@ openclaw gateway uninstall
`gateway discover` 会扫描 Gateway 网关信标(`_openclaw-gw._tcp`)。
-- 多播 DNS-SD:`local.`
-- 单播 DNS-SD(Wide-Area Bonjour):选择一个域名(例如:`openclaw.internal.`),并设置 split DNS + DNS 服务器;参见 [Bonjour](/zh-CN/gateway/bonjour)。
+- 组播 DNS-SD:`local.`
+- 单播 DNS-SD(广域 Bonjour):选择一个域名(例如:`openclaw.internal.`),并设置 split DNS + DNS 服务器;参见 [Bonjour](/zh-CN/gateway/bonjour)。
-只有启用了 Bonjour 发现(默认启用)的 gateway 才会通告该信标。
+只有启用了 Bonjour 设备发现的 gateway(默认启用)才会广播该信标。
-Wide-Area 发现记录包含(TXT):
+广域设备发现记录包含(TXT):
- `role`(gateway 角色提示)
- `transport`(传输提示,例如 `gateway`)
- `gatewayPort`(WebSocket 端口,通常为 `18789`)
-- `sshPort`(可选;当其缺失时,客户端会将默认 SSH 目标设为 `22`)
-- `tailnetDns`(MagicDNS 主机名,如果可用)
-- `gatewayTls` / `gatewayTlsSha256`(是否启用 TLS + 证书指纹)
+- `sshPort`(可选;缺失时,客户端默认 SSH 目标为 `22`)
+- `tailnetDns`(可用时的 MagicDNS 主机名)
+- `gatewayTls` / `gatewayTlsSha256`(TLS 已启用 + 证书指纹)
- `cliPath`(写入广域区域的远程安装提示)
### `gateway discover`
@@ -473,10 +509,10 @@ openclaw gateway discover
```
- 每个命令的超时时间(browse / resolve)。
+ 每条命令的超时时间(browse/resolve)。
- 机器可读输出(也会禁用样式 / spinner)。
+ 适合机器读取的输出(也会禁用样式 / spinner)。
示例:
@@ -487,12 +523,12 @@ openclaw gateway discover --json | jq '.beacons[].wsUrl'
```
-- CLI 会扫描 `local.` 以及已配置的广域域名(如果已启用)。
-- JSON 输出中的 `wsUrl` 是根据已解析的服务端点推导得出的,而不是来自 `lanHost` 或 `tailnetDns` 这类仅 TXT 的提示。
-- 在 `local.` mDNS 上,只有当 `discovery.mdns.mode` 为 `full` 时,才会广播 `sshPort` 和 `cliPath`。Wide-Area DNS-SD 仍会写入 `cliPath`;`sshPort` 在那里也仍然是可选的。
+- 当启用了广域域名时,CLI 会扫描 `local.` 以及已配置的广域域名。
+- JSON 输出中的 `wsUrl` 派生自已解析的服务端点,而不是仅来自 TXT 提示(如 `lanHost` 或 `tailnetDns`)。
+- 在 `local.` mDNS 上,只有当 `discovery.mdns.mode` 为 `full` 时,才会广播 `sshPort` 和 `cliPath`。广域 DNS-SD 仍会写入 `cliPath`;`sshPort` 在那里同样仍为可选。
-## 相关
+## 相关内容
- [CLI 参考](/zh-CN/cli)
- [Gateway 网关运行手册](/zh-CN/gateway)