Gateway lock(网关锁)
最后更新:2025-12-11
为什么
- 确保每个主机的每个基础端口只运行一个网关实例;其他网关必须使用隔离的配置文件和唯一端口。
- 在崩溃/SIGKILL 后存活而不留下陈旧的锁文件。
- 当控制端口已被占用时快速失败并显示清晰错误。
机制
- 网关在启动时立即绑定 WebSocket 监听器(默认 ws://127.0.0.1:18789),使用独占 TCP 监听器。
- 如果绑定失败并显示 EADDRINUSE,启动抛出 GatewayLockError("another gateway instance is already listening on ws://127.0.0.1:<port>")。
- 操作系统在任何进程退出时自动释放监听器,包括崩溃和 SIGKILL——不需要单独的锁文件或清理步骤。
- 关闭时,网关关闭 WebSocket 服务器和底层 HTTP 服务器以立即释放端口。
错误表面
- 如果另一个进程持有端口,启动抛出 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> 选择另一个。
- macOS 应用在生成网关前仍维护自己的轻量级 PID 保护;运行时锁由 WebSocket 绑定强制执行。