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 語意。
  • 可預測的記錄與監督。

如果未來再次需要真正的子行程模式,應將其記錄為獨立且明確的開發專用模式。

相關