Ciclo di vita del Gateway su macOS
L’app macOS gestisce il Gateway tramite launchd per impostazione predefinita e non avvia il Gateway come processo figlio. Per prima cosa prova a collegarsi a un Gateway già in esecuzione sulla porta configurata; se nessuno è raggiungibile, abilita il servizio launchd tramite la CLIopenclaw esterna (nessun runtime incorporato). Questo offre
avvio automatico affidabile al login e riavvio in caso di crash.
La modalità processo figlio (Gateway avviato direttamente dall’app) oggi non è in uso.
Se hai bisogno di un accoppiamento più stretto con l’interfaccia utente, esegui il Gateway manualmente in un terminale.
Comportamento predefinito (launchd)
- L’app installa un LaunchAgent per utente con etichetta
ai.openclaw.gateway(oppureai.openclaw.<profile>quando usi--profile/OPENCLAW_PROFILE;com.openclaw.*legacy è supportato). - Quando la modalità locale è abilitata, l’app assicura che il LaunchAgent sia caricato e avvia il Gateway se necessario.
- I log vengono scritti nel percorso del log del gateway launchd (visibile in Impostazioni di debug).
ai.openclaw.<profile> quando esegui un profilo nominato.
Build dev non firmate
scripts/restart-mac.sh --no-sign serve per build locali rapide quando non hai
chiavi di firma. Per impedire che launchd punti a un binario relay non firmato:
- Scrive
~/.openclaw/disable-launchagent.
scripts/restart-mac.sh rimuovono questo override se il marker
è presente. Per ripristinare manualmente:
Modalità solo collegamento
Per forzare l’app macOS a non installare né gestire mai launchd, avviala con--attach-only (oppure --no-launchd). Questo imposta ~/.openclaw/disable-launchagent,
quindi l’app si collega solo a un Gateway già in esecuzione. Puoi attivare lo stesso
comportamento anche nelle Impostazioni di debug.
Modalità remota
La modalità remota non avvia mai un Gateway locale. L’app usa un tunnel SSH verso l’host remoto e si connette attraverso quel tunnel.Perché preferiamo launchd
- Avvio automatico al login.
- Semantica integrata di riavvio/KeepAlive.
- Log e supervisione prevedibili.