macOS companion app
macOS 上的 Gateway 生命週期
macOS app 預設會透過 launchd 管理 Gateway,不會將 Gateway 生成為子行程。它會先嘗試連接到已在設定連接埠上執行的 Gateway;如果無法連線,則會透過外部 openclaw CLI 啟用 launchd 服務(沒有嵌入式執行階段)。這能提供可靠的登入時自動啟動,以及當機時重新啟動。
子行程模式(由 app 直接生成 Gateway)目前未使用。如果你需要與 UI 更緊密耦合,請在終端機中手動執行 Gateway。
預設行為(launchd)
- app 會安裝每位使用者專屬的 LaunchAgent,標籤為
ai.openclaw.gateway(或在使用--profile/OPENCLAW_PROFILE時為ai.openclaw.<profile>;支援舊版com.openclaw.*)。 - 啟用本機模式時,app 會確保 LaunchAgent 已載入,並在需要時啟動 Gateway。
- 記錄會寫入 launchd gateway 記錄路徑(可在偵錯設定中看到)。
常用命令:
launchctl kickstart -k gui/$UID/ai.openclaw.gateway
launchctl bootout gui/$UID/ai.openclaw.gateway
執行具名設定檔時,請將標籤替換為 ai.openclaw.<profile>。
未簽署的開發建置
scripts/restart-mac.sh --no-sign 適用於沒有簽署金鑰時的快速本機建置。為防止 launchd 指向未簽署的中繼二進位檔,它會:
- 寫入
~/.openclaw/disable-launchagent。
如果標記存在,已簽署的 scripts/restart-mac.sh 執行會清除此覆寫。若要手動重設:
rm ~/.openclaw/disable-launchagent
僅連接模式
若要強制 macOS app 永不安裝或管理 launchd,請使用 --attach-only(或 --no-launchd)啟動。這會設定 ~/.openclaw/disable-launchagent,因此 app 只會連接到已在執行的 Gateway。你也可以在偵錯設定中切換相同行為。
遠端模式
遠端模式絕不會啟動本機 Gateway。app 會使用 SSH 通道連到遠端主機,並透過該通道連線。
為什麼我們偏好 launchd
- 登入時自動啟動。
- 內建重新啟動/KeepAlive 語意。
- 可預測的記錄與監督。
如果未來再次需要真正的子行程模式,應將其記錄為獨立且明確的開發專用模式。