Gateway
Procedura operacyjna Gateway
Użyj tej strony do uruchomienia usługi Gateway w dniu 1 oraz operacji w dniu 2.
Diagnostyka od objawu z dokładnymi sekwencjami poleceń i sygnaturami logów.
Zadaniowy przewodnik konfiguracji + pełna dokumentacja konfiguracji.
Kontrakt SecretRef, zachowanie migawki środowiska uruchomieniowego oraz operacje migrate/reload.
Dokładne reguły celu/ścieżki secrets apply oraz zachowanie profilu uwierzytelniania tylko przez odwołania.
5-minutowe uruchomienie lokalne
Start the Gateway
openclaw gateway --port 18789# debug/trace mirrored to stdioopenclaw gateway --port 18789 --verbose# force-kill listener on selected port, then startopenclaw gateway --forceVerify service health
openclaw gateway statusopenclaw statusopenclaw logs --followZdrowa baza: Runtime: running, Connectivity probe: ok oraz Capability: ... zgodne z oczekiwaniami. Użyj openclaw gateway status --require-rpc, gdy potrzebujesz dowodu RPC w zakresie odczytu, a nie tylko osiągalności.
Validate channel readiness
openclaw channels status --probePrzy osiągalnym Gateway uruchamia to sondy kanałów na żywo dla każdego konta oraz opcjonalne audyty. Jeśli Gateway jest nieosiągalny, CLI zamiast wyników sond na żywo wraca do podsumowań kanałów tylko na podstawie konfiguracji.
Model środowiska uruchomieniowego
- Jeden stale działający proces do routingu, płaszczyzny sterowania i połączeń kanałów.
- Pojedynczy multipleksowany port dla:
- sterowania/RPC przez WebSocket
- API HTTP zgodnych z OpenAI (
/v1/models,/v1/embeddings,/v1/chat/completions,/v1/responses,/tools/invoke) - interfejsu sterowania i hooków
- Domyślny tryb wiązania:
loopback. - Uwierzytelnianie jest domyślnie wymagane. Konfiguracje ze współdzielonym sekretem używają
gateway.auth.token/gateway.auth.password(alboOPENCLAW_GATEWAY_TOKEN/OPENCLAW_GATEWAY_PASSWORD), a konfiguracje reverse proxy poza loopback mogą używaćgateway.auth.mode: "trusted-proxy".
Endpointy zgodne z OpenAI
Najważniejsza powierzchnia zgodności OpenClaw to teraz:
GET /v1/modelsGET /v1/models/{id}POST /v1/embeddingsPOST /v1/chat/completionsPOST /v1/responses
Dlaczego ten zestaw ma znaczenie:
- Większość integracji Open WebUI, LobeChat i LibreChat najpierw sprawdza
/v1/models. - Wiele potoków RAG i pamięci oczekuje
/v1/embeddings. - Klienci natywni dla agentów coraz częściej preferują
/v1/responses.
Uwaga planistyczna:
/v1/modelsjest ukierunkowane na agenty: zwracaopenclaw,openclaw/defaultiopenclaw/<agentId>.openclaw/defaultto stabilny alias, który zawsze mapuje się na skonfigurowanego agenta domyślnego.- Użyj
x-openclaw-model, gdy chcesz nadpisać dostawcę/model backendu; w przeciwnym razie wybrany agent zachowuje kontrolę nad swoim zwykłym modelem i konfiguracją embeddingów.
Wszystkie te endpointy działają na głównym porcie Gateway i używają tej samej granicy zaufanego uwierzytelniania operatora co reszta API HTTP Gateway.
Priorytet portu i wiązania
| Ustawienie | Kolejność rozwiązywania |
|---|---|
| Port Gateway | --port → OPENCLAW_GATEWAY_PORT → gateway.port → 18789 |
| Tryb wiązania | CLI/override → gateway.bind → loopback |
Zainstalowane usługi Gateway zapisują rozwiązany --port w metadanych nadzorcy. Po zmianie gateway.port uruchom openclaw doctor --fix albo openclaw gateway install --force, aby launchd/systemd/schtasks uruchamiał proces na nowym porcie.
Uruchomienie Gateway używa tego samego efektywnego portu i wiązania, gdy inicjuje lokalne
źródła interfejsu sterowania dla wiązań poza loopback. Na przykład --bind lan --port 3000
inicjuje http://localhost:3000 i http://127.0.0.1:3000, zanim zostanie uruchomiona
walidacja środowiska uruchomieniowego. Dodaj jawnie wszelkie źródła zdalnych przeglądarek,
takie jak adresy URL proxy HTTPS, do gateway.controlUi.allowedOrigins.
Tryby gorącego przeładowania
gateway.reload.mode |
Zachowanie |
|---|---|
off |
Brak przeładowania konfiguracji |
hot |
Zastosuj tylko zmiany bezpieczne na gorąco |
restart |
Uruchom ponownie przy zmianach wymagających przeładowania |
hybrid (domyślnie) |
Zastosuj na gorąco, gdy bezpieczne; uruchom ponownie, gdy wymagane |
Zestaw poleceń operatora
openclaw gateway statusopenclaw gateway status --deep # adds a system-level service scanopenclaw gateway status --jsonopenclaw gateway installopenclaw gateway restartopenclaw gateway stopopenclaw secrets reloadopenclaw logs --followopenclaw doctorgateway status --deep służy do dodatkowego wykrywania usług (LaunchDaemons/jednostki systemowe systemd/schtasks), a nie do głębszej sondy kondycji RPC.
Wiele Gateway (ten sam host)
Większość instalacji powinna uruchamiać jeden Gateway na maszynę. Pojedynczy Gateway może obsługiwać wiele agentów i kanałów.
Wiele Gateway jest potrzebnych tylko wtedy, gdy celowo chcesz izolacji albo bota ratunkowego.
Przydatne kontrole:
openclaw gateway status --deepopenclaw gateway probeCzego oczekiwać:
gateway status --deepmoże zgłosićOther gateway-like services detected (best effort)i wypisać wskazówki czyszczenia, gdy przestarzałe instalacje launchd/systemd/schtasks nadal istnieją.gateway probemoże ostrzec omultiple reachable gateways, gdy odpowiada więcej niż jeden cel.- Jeśli to celowe, izoluj porty, konfigurację/stan i katalogi główne obszarów roboczych dla każdego Gateway.
Lista kontrolna dla instancji:
- Unikalny
gateway.port - Unikalny
OPENCLAW_CONFIG_PATH - Unikalny
OPENCLAW_STATE_DIR - Unikalny
agents.defaults.workspace
Przykład:
OPENCLAW_CONFIG_PATH=~/.openclaw/a.json OPENCLAW_STATE_DIR=~/.openclaw-a openclaw gateway --port 19001OPENCLAW_CONFIG_PATH=~/.openclaw/b.json OPENCLAW_STATE_DIR=~/.openclaw-b openclaw gateway --port 19002Szczegółowa konfiguracja: /gateway/multiple-gateways.
Dostęp zdalny
Preferowane: Tailscale/VPN. Awaryjnie: tunel SSH.
ssh -N -L 18789:127.0.0.1:18789 user@hostNastępnie podłącz klientów lokalnie do ws://127.0.0.1:18789.
Zobacz: Zdalny Gateway, Uwierzytelnianie, Tailscale.
Nadzór i cykl życia usługi
Używaj nadzorowanych uruchomień dla niezawodności zbliżonej do produkcyjnej.
macOS (launchd)
openclaw gateway installopenclaw gateway statusopenclaw gateway restartopenclaw gateway stopUżywaj openclaw gateway restart do ponownych uruchomień. Nie łącz openclaw gateway stop i openclaw gateway start jako zamiennika restartu.
Na macOS gateway stop domyślnie używa launchctl bootout — usuwa to LaunchAgent z bieżącej sesji rozruchowej bez trwałego wyłączenia, więc automatyczne odzyskiwanie KeepAlive nadal działa po nieoczekiwanych awariach, a gateway start ponownie włącza usługę czysto. Aby trwale zatrzymać automatyczne ponowne uruchamianie między restartami systemu, przekaż --disable: openclaw gateway stop --disable.
Etykiety LaunchAgent to ai.openclaw.gateway (domyślnie) albo ai.openclaw.<profile> (nazwany profil). openclaw doctor audytuje i naprawia rozjazdy konfiguracji usługi.
Linux (systemd user)
openclaw gateway installsystemctl --user enable --now openclaw-gateway[-<profile>].serviceopenclaw gateway statusAby zachować działanie po wylogowaniu, włącz lingering:
sudo loginctl enable-linger <user>Przykład ręcznej jednostki użytkownika, gdy potrzebujesz niestandardowej ścieżki instalacji:
[Unit]Description=OpenClaw GatewayAfter=network-online.targetWants=network-online.target [Service]ExecStart=/usr/local/bin/openclaw gateway --port 18789Restart=alwaysRestartSec=5TimeoutStopSec=30TimeoutStartSec=30SuccessExitStatus=0 143KillMode=control-group [Install]WantedBy=default.targetWindows (native)
openclaw gateway installopenclaw gateway status --jsonopenclaw gateway restartopenclaw gateway stopNatywne zarządzane uruchamianie w Windows używa Zaplanowanego zadania o nazwie OpenClaw Gateway
(albo OpenClaw Gateway (<profile>) dla nazwanych profili). Jeśli utworzenie Zaplanowanego zadania
zostanie odrzucone, OpenClaw wróci do per-user launchera w folderze Autostart,
który wskazuje na gateway.cmd w katalogu stanu.
Linux (system service)
Użyj jednostki systemowej dla hostów wieloużytkownikowych/stale działających.
sudo systemctl daemon-reloadsudo systemctl enable --now openclaw-gateway[-<profile>].serviceUżyj tej samej treści usługi co jednostka użytkownika, ale zainstaluj ją w
/etc/systemd/system/openclaw-gateway[-<profile>].service i dostosuj
ExecStart=, jeśli plik binarny openclaw znajduje się gdzie indziej.
Nie pozwalaj jednocześnie, aby openclaw doctor --fix instalował usługę Gateway na poziomie użytkownika dla tego samego profilu/portu. Doctor odmawia takiej automatycznej instalacji, gdy znajdzie usługę OpenClaw Gateway na poziomie systemowym; użyj OPENCLAW_SERVICE_REPAIR_POLICY=external, gdy jednostka systemowa zarządza cyklem życia.
Szybka ścieżka profilu deweloperskiego
openclaw --dev setupopenclaw --dev gateway --allow-unconfiguredopenclaw --dev statusWartości domyślne obejmują izolowany stan/konfigurację oraz bazowy port Gateway 19001.
Szybka referencja protokołu (widok operatora)
- Pierwsza ramka klienta musi być
connect. - Gateway zwraca migawkę
hello-ok(presence,health,stateVersion,uptimeMs, limity/polityka). hello-ok.features.methods/eventsto konserwatywna lista wykrywania, a nie wygenerowany zrzut każdej możliwej do wywołania trasy pomocniczej.- Żądania:
req(method, params)→res(ok/payload|error). - Typowe zdarzenia obejmują
connect.challenge,agent,chat,session.message,session.tool,sessions.changed,presence,tick,health,heartbeat, zdarzenia cyklu życia parowania/zatwierdzania orazshutdown.
Uruchomienia agentów są dwuetapowe:
- Natychmiastowe potwierdzenie przyjęcia (
status:"accepted") - Końcowa odpowiedź zakończenia (
status:"ok"|"error"), z przesyłanymi po drodze zdarzeniamiagent.
Zobacz pełną dokumentację protokołu: Protokół Gateway.
Kontrole operacyjne
Żywotność
- Otwórz WS i wyślij
connect. - Oczekuj odpowiedzi
hello-okz migawką.
Gotowość
openclaw gateway statusopenclaw channels status --probeopenclaw healthOdzyskiwanie po lukach
Zdarzenia nie są odtwarzane. Przy lukach w sekwencji odśwież stan (health, system-presence) przed kontynuacją.
Typowe sygnatury awarii
| Sygnatura | Prawdopodobny problem |
|---|---|
refusing to bind gateway ... without auth |
Powiązanie spoza pętli zwrotnej bez prawidłowej ścieżki uwierzytelniania Gateway |
another gateway instance is already listening / EADDRINUSE |
Konflikt portu |
Gateway start blocked: set gateway.mode=local |
Konfiguracja ustawiona na tryb zdalny albo w uszkodzonej konfiguracji brakuje znacznika trybu lokalnego |
unauthorized during connect |
Niezgodność uwierzytelniania między klientem a Gateway |
Pełne ścieżki diagnostyczne znajdziesz w Rozwiązywanie problemów z Gateway.
Gwarancje bezpieczeństwa
- Klienci protokołu Gateway szybko kończą działanie, gdy Gateway jest niedostępny (bez niejawnego przełączania awaryjnego bezpośrednio na kanał).
- Nieprawidłowe pierwsze ramki lub pierwsze ramki bez połączenia są odrzucane i zamykane.
- Łagodne zamknięcie emituje zdarzenie
shutdownprzed zamknięciem gniazda.
Powiązane: