跳转到内容

Gateway(网关) 操作手册

使用此页面进行 Gateway(网关) 网关 服务的第 1 天启动和第 2 天运维。

Deep 故障排除

针对症状的诊断,提供确切的命令阶梯和日志特征。

Configuration

面向任务的设置指南 + 完整配置参考。

Secrets management

SecretRef 协定、运行时快照行为以及迁移/重载操作。

Secrets plan contract

精确的 secrets apply 目标/路径规则以及仅引用身份配置文件行为。

  1. Start the Gateway

    Terminal window
    openclaw gateway --port 18789
    # debug/trace mirrored to stdio
    openclaw gateway --port 18789 --verbose
    # force-kill listener on selected port, then start
    openclaw gateway --force
  2. Verify service health

    Terminal window
    openclaw gateway status
    openclaw status
    openclaw logs --follow

    健康基准:Runtime: runningRPC probe: ok

  3. Validate 渠道 readiness

    Terminal window
    openclaw channels status --probe

    如果网关可达,这将运行针对每个账户的实时渠道探测和可选审计。 如果网关不可达,CLI 将回退到仅配置的渠道摘要, 而不是实时探测输出。

  • 一个常驻进程用于路由、控制平面和渠道连接。
  • 单一多路复用端口用于:
    • WebSocket 控制/RPC
    • HTTP API,OpenAI 兼容 (/v1/models/v1/embeddings/v1/chat/completions/v1/responses/tools/invoke)
    • 控制 UI 和钩子
  • 默认绑定模式:loopback
  • 默认情况下需要身份验证。共享密钥设置使用 gateway.auth.token / gateway.auth.password(或 OPENCLAW_GATEWAY_TOKEN / OPENCLAW_GATEWAY_PASSWORD),非环回 反向代理设置可以使用 gateway.auth.mode: "trusted-proxy"

OpenClaw 目前最高杠杆的兼容性接口是:

  • GET /v1/models
  • GET /v1/models/{id}
  • POST /v1/embeddings
  • POST /v1/chat/completions
  • POST /v1/responses

为什么这一组很重要:

  • 大多数 Open WebUI、LobeChat 和 LibreChat 集成首先探测 /v1/models
  • 许多 RAG 和内存流水线期望使用 /v1/embeddings
  • Agent 原生客户端越来越倾向于使用 /v1/responses

规划说明:

  • /v1/models 是 Agent 优先的:它返回 openclawopenclaw/defaultopenclaw/<agentId>
  • openclaw/default 是一个稳定的别名,始终映射到配置的默认 Agent。
  • 当您想要后端提供商/模型覆盖时,请使用 x-openclaw-model;否则所选 Agent 的正常模型和嵌入设置将保持控制状态。

所有这些都在主 Gateway(网关) 端口上运行,并使用与 Gateway(网关) HTTP API 其余部分相同的可信操作员身份验证边界。

设置解析顺序
Gateway(网关) 端口--portOPENCLAW_GATEWAY_PORTgateway.port18789
绑定模式CLI/覆盖 → gateway.bindloopback
gateway.reload.mode行为
off无配置重载
hot仅应用热安全更改
restart需要重新加载时更改时重启
hybrid(默认)安全时热应用,需要时重启
Terminal window
openclaw gateway status
openclaw gateway status --deep # adds a system-level service scan
openclaw gateway status --json
openclaw gateway install
openclaw gateway restart
openclaw gateway stop
openclaw secrets reload
openclaw logs --follow
openclaw doctor

gateway status --deep 用于额外的服务发现(LaunchDaemons/systemd 系统 单元/schtasks),而非更深入的 RPC 运行状况探测。

大多数安装应在每台计算机上运行一个网关。单个网关可以托管多个 Agent 和通道。

仅当您有意想要隔离或救援机器人时,才需要多个网关。

有用的检查:

Terminal window
openclaw gateway status --deep
openclaw gateway probe

预期情况:

  • gateway status --deep 可以报告 Other gateway-like services detected (best effort) 并在存在过时的 launchd/systemd/schtasks 安装时打印清理提示。
  • 当多个目标响应时,gateway probe 可以针对 multiple reachable gateways 发出警告。
  • 如果是有意为之,请为每个 Gateway 隔离端口、配置/状态和工作区根目录。

详细设置:/gateway/multiple-gateways

首选:Tailscale/VPN。 备选:SSH 隧道。

Terminal window
ssh -N -L 18789:127.0.0.1:18789 user@host

然后将客户端连接到本地的 ws://127.0.0.1:18789

请参阅:Remote Gateway(网关)AuthenticationTailscale

使用受监管的运行方式以获得类似生产环境的可靠性。

Terminal window
openclaw gateway install
openclaw gateway status
openclaw gateway restart
openclaw gateway stop

LaunchAgent 标签为 ai.openclaw.gateway(默认)或 `ai.openclaw.

(命名配置文件)。openclaw doctor` 会审核并修复服务配置漂移。

大多数设置应运行 一个 Gateway(网关)。 仅在需要严格隔离/冗余(例如救援配置文件)时使用多个。

每个实例的检查清单:

  • 唯一的 gateway.port
  • 唯一的 OPENCLAW_CONFIG_PATH
  • 唯一的 OPENCLAW_STATE_DIR
  • 唯一的 agents.defaults.workspace

示例:

Terminal window
OPENCLAW_CONFIG_PATH=~/.openclaw/a.json OPENCLAW_STATE_DIR=~/.openclaw-a openclaw gateway --port 19001
OPENCLAW_CONFIG_PATH=~/.openclaw/b.json OPENCLAW_STATE_DIR=~/.openclaw-b openclaw gateway --port 19002

参见:多个网关

Terminal window
openclaw --dev setup
openclaw --dev gateway --allow-unconfigured
openclaw --dev status

默认值包括隔离的状态/配置和基本网关端口 19001

  • 第一个客户端帧必须是 connect
  • Gateway(网关) 返回 hello-ok 快照(presencehealthstateVersionuptimeMs、限制/策略)。
  • hello-ok.features.methods / events 是一个保守的发现列表,而不是 每个可调用辅助路由的生成转储。
  • 请求:req(method, params)res(ok/payload|error)
  • 常见事件包括 connect.challengeagentchatsession.messagesession.toolsessions.changedpresencetickhealthheartbeat、配对/批准生命周期事件以及 shutdown

代理运行分为两个阶段:

  1. 立即接受的确认(status:"accepted"
  2. 最终完成响应(status:"ok"|"error"),其间包含流式 agent 事件。

查看完整的协议文档:Gateway(网关) 协议

  • 打开 WS 并发送 connect
  • 期望收到带有快照的 hello-ok 响应。
Terminal window
openclaw gateway status
openclaw channels status --probe
openclaw health

事件不会重放。在出现序列间隙时,继续操作前请刷新状态 (health, system-presence)。

特征可能的问题
refusing to bind gateway ... without auth非回环绑定且没有有效的网关认证路径
another gateway instance is already listening / EADDRINUSE端口冲突
Gateway start blocked: set gateway.mode=local配置设置为远程模式,或者损坏的配置中缺少本地模式标记
连接期间出现 unauthorized客户端和网关之间的认证不匹配

如需完整的诊断流程,请使用 Gateway(网关) 故障排除

  • 当 Gateway(网关) 不可用时,Gateway(网关) 协议客户端会快速失败(没有隐式的直接渠道回退)。
  • 无效的或非连接的首帧会被拒绝并关闭连接。
  • 优雅关闭会在 socket 关闭之前发出 shutdown 事件。

相关: