Documentation Index
Fetch the complete documentation index at: https://openclaw.zhcndoc.com/llms.txt
Use this file to discover all available pages before exploring further.
为什么
- 确保在同一主机上每个基础端口只运行一个 gateway 实例;额外的 gateway 必须使用隔离的配置文件和唯一端口。
- 在崩溃/SIGKILL 后仍能存活,不留下陈旧的锁文件。
- 当控制端口已被占用时,快速失败并给出清晰的错误。
机制
- gateway 首先在状态锁目录下获取每个配置对应的锁文件,并探测已配置端口是否存在现有监听器。
- 如果记录的锁所有者已消失、端口空闲,或者锁已过期,则启动会重新获取锁并继续。
- 然后 gateway 使用独占 TCP 监听器绑定 HTTP/WebSocket 监听器(默认
ws://127.0.0.1:18789)。 - 如果绑定失败并返回
EADDRINUSE,启动将抛出GatewayLockError("another gateway instance is already listening on ws://127.0.0.1:<port>")。 - 关闭时,gateway 会关闭 HTTP/WebSocket 服务器并移除锁文件。
错误表面
- 如果另一个进程占用了该端口,启动会抛出
GatewayLockError("another gateway instance is already listening on ws://127.0.0.1:<port>")。 - 其他绑定失败会表现为
GatewayLockError("failed to bind gateway socket on ws://127.0.0.1:<port>: …")。
运维说明
- 如果该端口被 另一个 进程占用,错误是相同的;请释放该端口,或使用
openclaw gateway --port <port>选择其他端口。 - 在服务监督程序下,新的 gateway 进程如果检测到已有健康的
/healthz响应者,就会让该进程继续控制。在 systemd 上,重复启动器会以代码 78 退出,因此默认的RestartPreventExitStatus=78会阻止Restart=always因锁或EADDRINUSE冲突而反复重启。如果现有进程始终无法变为健康,重试会被限制,启动会以清晰的锁错误失败,而不是无限循环。 - macOS 应用在启动 gateway 之前仍会维护自己的轻量级 PID 守卫;运行时锁由锁文件加上 HTTP/WebSocket 绑定共同强制执行。
相关内容
- 多个 Gateways — 使用唯一端口运行多个实例
- 故障排除 — 诊断
EADDRINUSE和端口冲突