网关锁

适用范围

在以下情况使用此页面:

  • 运行或调试网关进程
  • 调查单实例强制执行

最后更新:2025-12-11

为什么

  • 确保在同一主机上每个基础端口只运行一个网关实例;额外的网关必须使用隔离的配置文件和唯一端口。
  • 在崩溃/SIGKILL 后幸存而不会留下过时的锁文件。
  • 当控制端口已被占用时,通过清晰的错误快速失败。

机制

  • 网关在启动时使用独占 TCP 监听器立即绑定 WebSocket 监听器(默认 ws://127.0.0.1:18789)。
  • 如果绑定因 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>: …")

操作注意事项

  • 如果端口被另一个进程占用,错误相同;释放端口或使用 moltbot gateway --port <port> 选择另一个端口。
  • macOS 应用在生成网关之前仍维护自己的轻量级 PID 保护;运行时锁定由 WebSocket 绑定强制执行。