FAQ
Häufig gestellte Fragen
Schnelle Antworten plus tiefergehende Fehlerbehebung für reale Setups (lokale Entwicklung, VPS, Multi-Agent, OAuth/API-Schlüssel, Modell-Failover). Laufzeitdiagnosen finden Sie unter Fehlerbehebung. Die vollständige Konfigurationsreferenz finden Sie unter Konfiguration.
Erste 60 Sekunden, wenn etwas defekt ist
-
Schneller Status (erste Prüfung)
bash openclaw statusSchnelle lokale Zusammenfassung: Betriebssystem + Update, Erreichbarkeit von Gateway/Dienst, Agenten/Sitzungen, Provider-Konfiguration + Laufzeitprobleme (wenn das Gateway erreichbar ist).
-
Einfügbarer Bericht (sicher teilbar)
bash openclaw status --allSchreibgeschützte Diagnose mit Log-Auszug (Token redigiert).
-
Daemon- + Port-Status
bash openclaw gateway statusZeigt Supervisor-Laufzeit vs. RPC-Erreichbarkeit, die Ziel-URL des Probes und welche Konfiguration der Dienst wahrscheinlich verwendet hat.
-
Tiefe Probes
bash openclaw status --deepFührt einen Live-Gateway-Health-Probe aus, einschließlich Channel-Probes, wenn unterstützt (erfordert ein erreichbares Gateway). Siehe Health.
-
Aktuellstes Log verfolgen
bash openclaw logs --followWenn RPC nicht erreichbar ist, verwenden Sie alternativ:
bash tail -f "$(ls -t /tmp/openclaw/openclaw-*.log | head -1)"Datei-Logs sind von Dienst-Logs getrennt; siehe Logging und Fehlerbehebung.
-
Doctor ausführen (Reparaturen)
bash openclaw doctorRepariert/migriert Konfiguration/Zustand + führt Health-Checks aus. Siehe Doctor.
-
Gateway-Snapshot
bash openclaw health --jsonopenclaw health --verbose # zeigt bei Fehlern die Ziel-URL + den KonfigurationspfadFragt das laufende Gateway nach einem vollständigen Snapshot (nur WS). Siehe Health.
Schnellstart und Einrichtung beim ersten Start
Fragen und Antworten zum ersten Start — Installation, Onboarding, Auth-Routen, Abonnements, anfängliche Fehler — finden Sie in der FAQ zum ersten Start.
Was ist OpenClaw?
Was ist OpenClaw in einem Absatz?
OpenClaw ist ein persönlicher KI-Assistent, den Sie auf Ihren eigenen Geräten ausführen. Er antwortet auf den Messaging-Oberflächen, die Sie bereits verwenden (WhatsApp, Telegram, Slack, Mattermost, Discord, Google Chat, Signal, iMessage, WebChat und gebündelte Channel-Plugins wie QQ Bot), und kann auf unterstützten Plattformen auch Sprache + ein Live-Canvas nutzen. Das Gateway ist die ständig aktive Steuerungsebene; der Assistent ist das Produkt.
Wertversprechen
OpenClaw ist nicht „nur ein Claude-Wrapper“. Es ist eine Local-first-Steuerungsebene, mit der Sie einen leistungsfähigen Assistenten auf Ihrer eigenen Hardware ausführen können, erreichbar über die Chat-Apps, die Sie bereits verwenden, mit zustandsbehafteten Sitzungen, Speicher und Tools - ohne die Kontrolle über Ihre Workflows an ein gehostetes SaaS abzugeben.
Highlights:
- Ihre Geräte, Ihre Daten: Führen Sie das Gateway aus, wo Sie möchten (Mac, Linux, VPS), und halten Sie Workspace + Sitzungshistorie lokal.
- Echte Channels, keine Web-Sandbox: WhatsApp/Telegram/Slack/Discord/Signal/iMessage/usw., plus mobile Sprache und Canvas auf unterstützten Plattformen.
- Modellagnostisch: Nutzen Sie Anthropic, OpenAI, MiniMax, OpenRouter usw. mit Routing und Failover pro Agent.
- Option nur lokal: Führen Sie lokale Modelle aus, sodass alle Daten auf Ihrem Gerät bleiben können, wenn Sie das möchten.
- Multi-Agent-Routing: getrennte Agenten pro Channel, Konto oder Aufgabe, jeweils mit eigenem Workspace und eigenen Standardeinstellungen.
- Open Source und hackbar: prüfen, erweitern und selbst hosten ohne Vendor-Lock-in.
Doku: Gateway, Channels, Multi-Agent, Memory.
Ich habe es gerade eingerichtet - was sollte ich zuerst tun?
Gute erste Projekte:
- Eine Website erstellen (WordPress, Shopify oder eine einfache statische Website).
- Einen Prototyp für eine mobile App erstellen (Gliederung, Screens, API-Plan).
- Dateien und Ordner organisieren (Aufräumen, Benennung, Tagging).
- Gmail verbinden und Zusammenfassungen oder Follow-ups automatisieren.
Es kann große Aufgaben bewältigen, funktioniert aber am besten, wenn Sie sie in Phasen aufteilen und Sub-Agents für parallele Arbeit verwenden.
Was sind die fünf wichtigsten alltäglichen Anwendungsfälle für OpenClaw?
Alltägliche Erfolge sehen normalerweise so aus:
- Persönliche Briefings: Zusammenfassungen von Posteingang, Kalender und Nachrichten, die Sie interessieren.
- Recherche und Entwurf: schnelle Recherche, Zusammenfassungen und erste Entwürfe für E-Mails oder Dokumente.
- Erinnerungen und Follow-ups: Cron- oder Heartbeat-gesteuerte Hinweise und Checklisten.
- Browser-Automatisierung: Formulare ausfüllen, Daten sammeln und Webaufgaben wiederholen.
- Geräteübergreifende Koordination: Senden Sie eine Aufgabe von Ihrem Telefon, lassen Sie das Gateway sie auf einem Server ausführen und erhalten Sie das Ergebnis im Chat zurück.
Kann OpenClaw bei Lead-Generierung, Outreach, Anzeigen und Blogs für ein SaaS helfen?
Ja, für Recherche, Qualifizierung und Entwürfe. Es kann Websites scannen, Auswahllisten erstellen, potenzielle Kunden zusammenfassen und Entwürfe für Outreach- oder Anzeigentexte schreiben.
Bei Outreach- oder Anzeigenkampagnen sollten Menschen eingebunden bleiben. Vermeiden Sie Spam, halten Sie lokale Gesetze und Plattformrichtlinien ein und prüfen Sie alles, bevor es gesendet wird. Das sicherste Muster ist, OpenClaw entwerfen zu lassen und selbst freizugeben.
Doku: Security.
Welche Vorteile hat es gegenüber Claude Code für Webentwicklung?
OpenClaw ist ein persönlicher Assistent und eine Koordinationsschicht, kein IDE-Ersatz. Verwenden Sie Claude Code oder Codex für die schnellste direkte Coding-Schleife innerhalb eines Repos. Verwenden Sie OpenClaw, wenn Sie dauerhaften Speicher, geräteübergreifenden Zugriff und Tool-Orchestrierung wünschen.
Vorteile:
- Persistenter Speicher + Workspace über Sitzungen hinweg
- Multi-Plattform-Zugriff (WhatsApp, Telegram, TUI, WebChat)
- Tool-Orchestrierung (Browser, Dateien, Planung, Hooks)
- Ständig aktives Gateway (auf einem VPS ausführen, von überall interagieren)
- Nodes für lokalen Browser/Bildschirm/Kamera/Exec
Showcase: https://openclaw.ai/showcase
Skills und Automatisierung
Wie passe ich Skills an, ohne das Repo dirty zu halten?
Verwenden Sie verwaltete Overrides, statt die Repo-Kopie zu bearbeiten. Legen Sie Ihre Änderungen in ~/.openclaw/skills/<name>/SKILL.md ab (oder fügen Sie einen Ordner über skills.load.extraDirs in ~/.openclaw/openclaw.json hinzu). Die Priorität ist <workspace>/skills → <workspace>/.agents/skills → ~/.agents/skills → ~/.openclaw/skills → gebündelt → skills.load.extraDirs, sodass verwaltete Overrides weiterhin Vorrang vor gebündelten Skills haben, ohne git zu berühren. Wenn der Skill global installiert, aber nur für einige Agenten sichtbar sein soll, behalten Sie die gemeinsame Kopie in ~/.openclaw/skills und steuern Sie die Sichtbarkeit mit agents.defaults.skills und agents.list[].skills. Nur Änderungen, die für Upstream geeignet sind, sollten im Repo liegen und als PRs eingereicht werden.
Kann ich Skills aus einem benutzerdefinierten Ordner laden?
Ja. Fügen Sie zusätzliche Verzeichnisse über skills.load.extraDirs in ~/.openclaw/openclaw.json hinzu (niedrigste Priorität). Die Standardpriorität ist <workspace>/skills → <workspace>/.agents/skills → ~/.agents/skills → ~/.openclaw/skills → gebündelt → skills.load.extraDirs. clawhub installiert standardmäßig in ./skills, was OpenClaw in der nächsten Sitzung als <workspace>/skills behandelt. Wenn der Skill nur für bestimmte Agenten sichtbar sein soll, kombinieren Sie dies mit agents.defaults.skills oder agents.list[].skills.
Wie kann ich unterschiedliche Modelle für unterschiedliche Aufgaben verwenden?
Die heute unterstützten Muster sind:
- Cron-Jobs: Isolierte Jobs können pro Job einen
model-Override setzen. - Sub-Agents: Leiten Sie Aufgaben an separate Agenten mit unterschiedlichen Standardmodellen weiter.
- Wechsel bei Bedarf: Verwenden Sie
/model, um das aktuelle Sitzungsmodell jederzeit zu wechseln.
Siehe Cron-Jobs, Multi-Agent-Routing und Slash-Befehle.
Der Bot friert bei schwerer Arbeit ein. Wie lagere ich das aus?
Verwenden Sie Sub-Agents für lange oder parallele Aufgaben. Sub-Agents laufen in ihrer eigenen Sitzung, geben eine Zusammenfassung zurück und halten Ihren Hauptchat reaktionsfähig.
Bitten Sie Ihren Bot, „einen Sub-Agent für diese Aufgabe zu starten“, oder verwenden Sie /subagents.
Verwenden Sie /status im Chat, um zu sehen, was das Gateway gerade tut (und ob es ausgelastet ist).
Token-Tipp: Lange Aufgaben und Sub-Agents verbrauchen beide Token. Wenn Kosten wichtig sind, legen Sie über
agents.defaults.subagents.model ein günstigeres Modell für Sub-Agents fest.
Doku: Sub-Agents, Hintergrundaufgaben.
Wie funktionieren threadgebundene Subagent-Sitzungen auf Discord?
Verwenden Sie Thread-Bindungen. Sie können einen Discord-Thread an einen Subagent oder ein Sitzungsziel binden, sodass Follow-up-Nachrichten in diesem Thread in der gebundenen Sitzung bleiben.
Grundlegender Ablauf:
- Starten Sie mit
sessions_spawnunter Verwendung vonthread: true(und optionalmode: "session"für persistentes Follow-up). - Oder binden Sie manuell mit
/focus <target>. - Verwenden Sie
/agents, um den Bindungsstatus zu prüfen. - Verwenden Sie
/session idle <duration|off>und/session max-age <duration|off>, um Auto-Unfocus zu steuern. - Verwenden Sie
/unfocus, um den Thread zu lösen.
Erforderliche Konfiguration:
- Globale Standardwerte:
session.threadBindings.enabled,session.threadBindings.idleHours,session.threadBindings.maxAgeHours. - Discord-Overrides:
channels.discord.threadBindings.enabled,channels.discord.threadBindings.idleHours,channels.discord.threadBindings.maxAgeHours. - Automatische Bindung beim Start:
channels.discord.threadBindings.spawnSessionsist standardmäßigtrue; setzen Sie es auffalse, um threadgebundene Sitzungsstarts zu deaktivieren.
Doku: Sub-Agents, Discord, Konfigurationsreferenz, Slash-Befehle.
Ein Subagent ist fertig, aber die Abschlussaktualisierung ging an den falschen Ort oder wurde nie gepostet. Was sollte ich prüfen?
Prüfen Sie zuerst die aufgelöste Requester-Route:
- Die Zustellung von Subagents im Completion-Modus bevorzugt jede gebundene Thread- oder Konversationsroute, wenn eine vorhanden ist.
- Wenn der Completion-Ursprung nur einen Channel enthält, fällt OpenClaw auf die gespeicherte Route der Requester-Sitzung zurück (
lastChannel/lastTo/lastAccountId), damit die direkte Zustellung weiterhin gelingen kann. - Wenn weder eine gebundene Route noch eine verwendbare gespeicherte Route vorhanden ist, kann die direkte Zustellung fehlschlagen und das Ergebnis fällt auf die Zustellung über die Warteschlange der Sitzung zurück, statt sofort im Chat gepostet zu werden.
- Ungültige oder veraltete Ziele können weiterhin einen Fallback auf die Warteschlange oder einen endgültigen Zustellungsfehler erzwingen.
- Wenn die letzte sichtbare Assistant-Antwort des Childs exakt das stille Token
NO_REPLY/no_replyoder exaktANNOUNCE_SKIPist, unterdrückt OpenClaw die Ankündigung absichtlich, statt veralteten früheren Fortschritt zu posten. - Wenn das Child nach ausschließlich Tool-Aufrufen ein Timeout hatte, kann die Ankündigung dies zu einer kurzen Zusammenfassung des Teilfortschritts zusammenfassen, statt rohe Tool-Ausgabe erneut wiederzugeben.
Debug:
openclaw tasks show <runId-or-sessionKey>Doku: Sub-Agents, Hintergrundaufgaben, Sitzungstools.
Cron oder Erinnerungen werden nicht ausgelöst. Was sollte ich prüfen?
Cron läuft innerhalb des Gateway-Prozesses. Wenn das Gateway nicht kontinuierlich läuft, werden geplante Jobs nicht ausgeführt.
Checkliste:
- Bestätigen Sie, dass Cron aktiviert ist (
cron.enabled) undOPENCLAW_SKIP_CRONnicht gesetzt ist. - Prüfen Sie, dass das Gateway rund um die Uhr läuft (kein Ruhezustand/keine Neustarts).
- Überprüfen Sie die Zeitzoneneinstellungen für den Job (
--tzvs host timezone).
Debug:
openclaw cron run <jobId>openclaw cron runs --id <jobId> --limit 50Doku: Cron-Jobs, Automatisierung.
Cron wurde ausgelöst, aber es wurde nichts an den Kanal gesendet. Warum?
Prüfen Sie zuerst den Zustellmodus:
--no-deliver/delivery.mode: "none"bedeutet, dass kein Fallback-Versand durch den Runner erwartet wird.- Ein fehlendes oder ungültiges Ankündigungsziel (
channel/to) bedeutet, dass der Runner die ausgehende Zustellung übersprungen hat. - Authentifizierungsfehler des Kanals (
unauthorized,Forbidden) bedeuten, dass der Runner versucht hat zuzustellen, die Zugangsdaten dies aber blockiert haben. - Ein stilles isoliertes Ergebnis (nur
NO_REPLY/no_reply) wird als absichtlich nicht zustellbar behandelt, daher unterdrückt der Runner auch die eingereihte Fallback-Zustellung.
Bei isolierten Cron-Jobs kann der Agent weiterhin direkt mit dem Tool message
senden, wenn eine Chat-Route verfügbar ist. --announce steuert nur den
Fallback-Pfad des Runners für abschließenden Text, den der Agent nicht bereits gesendet hat.
Debug:
openclaw cron runs --id <jobId> --limit 50openclaw tasks show <runId-or-sessionKey>Dokumentation: Cron-Jobs, Hintergrundaufgaben.
Warum hat ein isolierter Cron-Lauf das Modell gewechselt oder einmal erneut versucht?
Das ist normalerweise der Live-Modellwechselpfad, keine doppelte Planung.
Isolierter Cron kann eine Laufzeit-Modellübergabe speichern und erneut versuchen, wenn der aktive
Lauf LiveSessionModelSwitchError auslöst. Der erneute Versuch behält den gewechselten
Provider bzw. das gewechselte Modell bei, und wenn der Wechsel eine neue Auth-Profil-Überschreibung mitgeführt hat, speichert Cron
auch diese vor dem erneuten Versuch.
Zugehörige Auswahlregeln:
- Die Gmail-Hook-Modellüberschreibung gewinnt zuerst, wenn sie anwendbar ist.
- Danach
modelpro Job. - Danach jede gespeicherte Cron-Sitzungs-Modellüberschreibung.
- Danach die normale Agent-/Standardmodellauswahl.
Die Wiederholungsschleife ist begrenzt. Nach dem ersten Versuch plus 2 Wechsel-Wiederholungen bricht Cron ab, statt endlos weiterzulaufen.
Debug:
openclaw cron runs --id <jobId> --limit 50openclaw tasks show <runId-or-sessionKey>Wie installiere ich Skills unter Linux?
Verwenden Sie native openclaw skills-Befehle oder legen Sie Skills in Ihrem Workspace ab. Die macOS-Skills-Benutzeroberfläche ist unter Linux nicht verfügbar.
Durchsuchen Sie Skills unter https://clawhub.ai.
openclaw skills search "calendar"openclaw skills search --limit 20openclaw skills install <skill-slug>openclaw skills install <skill-slug> --version <version>openclaw skills install <skill-slug> --forceopenclaw skills update --allopenclaw skills list --eligibleopenclaw skills checkNatives openclaw skills install schreibt in das Verzeichnis skills/
des aktiven Workspace. Installieren Sie die separate clawhub-CLI nur, wenn Sie eigene Skills veröffentlichen oder
synchronisieren möchten. Für gemeinsame Installationen über mehrere Agents hinweg legen Sie den Skill unter
~/.openclaw/skills ab und verwenden Sie agents.defaults.skills oder
agents.list[].skills, wenn Sie einschränken möchten, welche Agents ihn sehen können.
Kann OpenClaw Aufgaben geplant oder kontinuierlich im Hintergrund ausführen?
Ja. Verwenden Sie den Gateway-Scheduler:
- Cron-Jobs für geplante oder wiederkehrende Aufgaben (bleiben über Neustarts hinweg bestehen).
- Heartbeat für periodische Prüfungen der „Hauptsitzung“.
- Isolierte Jobs für autonome Agents, die Zusammenfassungen posten oder an Chats zustellen.
Dokumentation: Cron-Jobs, Automatisierung, Heartbeat.
Kann ich reine Apple-macOS-Skills von Linux aus ausführen?
Nicht direkt. macOS-Skills werden durch metadata.openclaw.os plus erforderliche Binärdateien eingeschränkt, und Skills erscheinen nur dann im System-Prompt, wenn sie auf dem Gateway-Host zulässig sind. Unter Linux werden nur für darwin bestimmte Skills (wie apple-notes, apple-reminders, things-mac) nicht geladen, sofern Sie das Gating nicht überschreiben.
Sie haben drei unterstützte Muster:
Option A - Gateway auf einem Mac ausführen (am einfachsten). Führen Sie den Gateway dort aus, wo die macOS-Binärdateien vorhanden sind, und verbinden Sie sich dann von Linux im Remote-Modus oder über Tailscale. Die Skills werden normal geladen, weil der Gateway-Host macOS ist.
Option B - macOS-Node verwenden (kein SSH).
Führen Sie den Gateway unter Linux aus, koppeln Sie einen macOS-Node (Menüleisten-App) und setzen Sie Node-Ausführungsbefehle auf dem Mac auf „Immer fragen“ oder „Immer erlauben“. OpenClaw kann reine macOS-Skills als zulässig behandeln, wenn die erforderlichen Binärdateien auf dem Node vorhanden sind. Der Agent führt diese Skills über das Tool nodes aus. Wenn Sie „Immer fragen“ wählen, fügt die Bestätigung von „Immer erlauben“ in der Eingabeaufforderung diesen Befehl zur Allowlist hinzu.
Option C - macOS-Binärdateien über SSH proxyn (fortgeschritten). Behalten Sie den Gateway unter Linux, sorgen Sie aber dafür, dass die erforderlichen CLI-Binärdateien zu SSH-Wrappern auflösen, die auf einem Mac ausgeführt werden. Überschreiben Sie dann den Skill, um Linux zu erlauben, damit er zulässig bleibt.
-
Erstellen Sie einen SSH-Wrapper für die Binärdatei (Beispiel:
memofür Apple Notes):bash #!/usr/bin/env bashset -euo pipefailexec ssh -T user@mac-host /opt/homebrew/bin/memo "$@" -
Legen Sie den Wrapper auf dem Linux-Host in
PATHab (zum Beispiel~/bin/memo). -
Überschreiben Sie die Skill-Metadaten (Workspace oder
~/.openclaw/skills), um Linux zu erlauben:markdown ---name: apple-notesdescription: Manage Apple Notes via the memo CLI on macOS.metadata: { "openclaw": { "os": ["darwin", "linux"], "requires": { "bins": ["memo"] } } }--- -
Starten Sie eine neue Sitzung, damit der Skills-Snapshot aktualisiert wird.
Gibt es eine Notion- oder HeyGen-Integration?
Heute nicht integriert.
Optionen:
- Benutzerdefinierter Skill / Plugin: am besten für zuverlässigen API-Zugriff (Notion/HeyGen haben beide APIs).
- Browser-Automatisierung: funktioniert ohne Code, ist aber langsamer und fragiler.
Wenn Sie Kontext pro Kunde behalten möchten (Agentur-Workflows), ist ein einfaches Muster:
- Eine Notion-Seite pro Kunde (Kontext + Präferenzen + aktive Arbeit).
- Bitten Sie den Agent, diese Seite zu Beginn einer Sitzung abzurufen.
Wenn Sie eine native Integration wünschen, öffnen Sie eine Funktionsanfrage oder erstellen Sie einen Skill, der auf diese APIs abzielt.
Skills installieren:
openclaw skills install <skill-slug>openclaw skills update --allNative Installationen landen im Verzeichnis skills/ des aktiven Workspace. Für gemeinsame Skills über mehrere Agents hinweg platzieren Sie sie in ~/.openclaw/skills/<name>/SKILL.md. Wenn nur einige Agents eine gemeinsame Installation sehen sollen, konfigurieren Sie agents.defaults.skills oder agents.list[].skills. Einige Skills erwarten Binärdateien, die über Homebrew installiert wurden; unter Linux bedeutet das Linuxbrew (siehe den Homebrew-Linux-FAQ-Eintrag oben). Siehe Skills, Skills-Konfiguration und ClawHub.
Wie verwende ich mein vorhandenes angemeldetes Chrome mit OpenClaw?
Verwenden Sie das integrierte Browserprofil user, das über Chrome DevTools MCP angebunden wird:
openclaw browser --browser-profile user tabsopenclaw browser --browser-profile user snapshotWenn Sie einen benutzerdefinierten Namen möchten, erstellen Sie ein explizites MCP-Profil:
openclaw browser create-profile --name chrome-live --driver existing-sessionopenclaw browser --browser-profile chrome-live tabsDieser Pfad kann den lokalen Host-Browser oder einen verbundenen Browser-Node verwenden. Wenn der Gateway anderswo läuft, führen Sie entweder einen Node-Host auf der Browser-Maschine aus oder verwenden Sie stattdessen Remote-CDP.
Aktuelle Grenzen von existing-session / user:
- Aktionen sind ref-gesteuert, nicht CSS-Selektor-gesteuert
- Uploads erfordern
ref/inputRefund unterstützen derzeit jeweils eine Datei responsebody, PDF-Export, Download-Abfangen und Batch-Aktionen benötigen weiterhin einen verwalteten Browser oder ein Raw-CDP-Profil
Sandboxing und Speicher
Gibt es eine dedizierte Sandboxing-Dokumentation?
Ja. Siehe Sandboxing. Für Docker-spezifische Einrichtung (vollständiger Gateway in Docker oder Sandbox-Images) siehe Docker.
Docker fühlt sich eingeschränkt an - wie aktiviere ich den vollen Funktionsumfang?
Das Standard-Image ist auf Sicherheit ausgelegt und läuft als Benutzer node, daher enthält es keine
Systempakete, Homebrew oder gebündelten Browser. Für eine umfassendere Einrichtung:
- Persistieren Sie
/home/nodemitOPENCLAW_HOME_VOLUME, damit Caches erhalten bleiben. - Backen Sie Systemabhängigkeiten mit
OPENCLAW_DOCKER_APT_PACKAGESin das Image. - Installieren Sie Playwright-Browser über die gebündelte CLI:
node /app/node_modules/playwright-core/cli.js install chromium - Setzen Sie
PLAYWRIGHT_BROWSERS_PATHund stellen Sie sicher, dass der Pfad persistiert wird.
Kann ich DMs persönlich halten, Gruppen aber mit einem Agent öffentlich/sandboxed machen?
Ja - wenn Ihr privater Datenverkehr DMs und Ihr öffentlicher Datenverkehr Gruppen sind.
Verwenden Sie agents.defaults.sandbox.mode: "non-main", damit Gruppen-/Kanalsitzungen (Nicht-Hauptschlüssel) im konfigurierten Sandbox-Backend laufen, während die Haupt-DM-Sitzung auf dem Host bleibt. Docker ist das Standard-Backend, wenn Sie keines auswählen. Schränken Sie dann über tools.sandbox.tools ein, welche Tools in sandboxed Sitzungen verfügbar sind.
Einrichtungsanleitung + Beispielkonfiguration: Gruppen: persönliche DMs + öffentliche Gruppen
Wichtige Konfigurationsreferenz: Gateway-Konfiguration
Wie binde ich einen Host-Ordner in die Sandbox ein?
Setzen Sie agents.defaults.sandbox.docker.binds auf ["host:path:mode"] (z. B. "/home/user/src:/src:ro"). Globale und agentenspezifische Bind-Mounts werden zusammengeführt; agentenspezifische Bind-Mounts werden ignoriert, wenn scope: "shared" gilt. Verwenden Sie :ro für alles Sensible und denken Sie daran, dass Bind-Mounts die Dateisystemgrenzen der Sandbox umgehen.
OpenClaw validiert Bind-Quellen sowohl gegen den normalisierten Pfad als auch gegen den kanonischen Pfad, der über den tiefsten vorhandenen Vorgänger aufgelöst wird. Das bedeutet, dass Ausbrüche über Symlink-Eltern weiterhin geschlossen fehlschlagen, selbst wenn das letzte Pfadsegment noch nicht existiert, und dass Allowed-Root-Prüfungen auch nach der Symlink-Auflösung weiterhin gelten.
Siehe Sandboxing und Sandbox vs. Tool-Richtlinie vs. Erhöht für Beispiele und Sicherheitshinweise.
Wie funktioniert Speicher?
OpenClaw-Speicher besteht einfach aus Markdown-Dateien im Agent-Workspace:
- Tägliche Notizen in
memory/YYYY-MM-DD.md - Kuratierte Langzeitnotizen in
MEMORY.md(nur Haupt-/private Sitzungen)
OpenClaw führt außerdem einen stillen Speicher-Flush vor der Compaction aus, um das Modell daran zu erinnern, dauerhafte Notizen zu schreiben, bevor die automatische Compaction erfolgt. Dies läuft nur, wenn der Workspace beschreibbar ist (schreibgeschützte Sandboxes überspringen es). Siehe Speicher.
Der Speicher vergisst ständig Dinge. Wie sorge ich dafür, dass sie bleiben?
Bitten Sie den Bot, die Tatsache in den Speicher zu schreiben. Langzeitnotizen gehören in MEMORY.md,
kurzfristiger Kontext kommt in memory/YYYY-MM-DD.md.
Dies ist weiterhin ein Bereich, den wir verbessern. Es hilft, das Modell daran zu erinnern, Erinnerungen zu speichern; es weiß, was zu tun ist. Wenn es weiterhin vergisst, prüfen Sie, ob der Gateway bei jedem Lauf denselben Workspace verwendet.
Dokumentation: Speicher, Agent-Workspace.
Bleibt Speicher für immer bestehen? Was sind die Grenzen?
Speicherdateien liegen auf der Festplatte und bleiben bestehen, bis Sie sie löschen. Die Grenze ist Ihr Speicherplatz, nicht das Modell. Der Sitzungskontext ist weiterhin durch das Kontextfenster des Modells begrenzt, daher können lange Unterhaltungen komprimiert oder gekürzt werden. Deshalb gibt es die Speichersuche - sie holt nur die relevanten Teile zurück in den Kontext.
Erfordert die semantische Speichersuche einen OpenAI-API-Schlüssel?
Nur wenn Sie OpenAI Embeddings verwenden. Codex OAuth deckt Chat/Completions ab und
gewährt keinen Zugriff auf Embeddings, daher hilft die Anmeldung mit Codex (OAuth oder der
Codex CLI-Anmeldung) nicht bei der semantischen Speichersuche. OpenAI Embeddings
benötigen weiterhin einen echten API-Schlüssel (OPENAI_API_KEY oder models.providers.openai.apiKey).
Wenn Sie keinen Provider explizit festlegen, wählt OpenClaw automatisch einen Provider aus, wenn es
einen API-Schlüssel auflösen kann (Auth-Profile, models.providers.*.apiKey oder Umgebungsvariablen).
OpenAI wird bevorzugt, wenn ein OpenAI-Schlüssel aufgelöst wird, andernfalls Gemini, wenn ein Gemini-Schlüssel
aufgelöst wird, danach Voyage und dann Mistral. Wenn kein Remote-Schlüssel verfügbar ist, bleibt die
Speichersuche deaktiviert, bis Sie sie konfigurieren. Wenn ein lokaler Modellpfad
konfiguriert und vorhanden ist, bevorzugt OpenClaw
local. Ollama wird unterstützt, wenn Sie explizit
memorySearch.provider = "ollama" festlegen.
Wenn Sie lieber lokal bleiben möchten, setzen Sie memorySearch.provider = "local" (und optional
memorySearch.fallback = "none"). Wenn Sie Gemini Embeddings verwenden möchten, setzen Sie
memorySearch.provider = "gemini" und stellen Sie GEMINI_API_KEY (oder
memorySearch.remote.apiKey) bereit. Wir unterstützen OpenAI, Gemini, Voyage, Mistral, Ollama oder lokale Embedding-
Modelle - siehe Memory für die Einrichtungsdetails.
Wo Dinge auf der Festplatte liegen
Werden alle mit OpenClaw verwendeten Daten lokal gespeichert?
Nein - der Zustand von OpenClaw ist lokal, aber externe Dienste sehen weiterhin, was Sie an sie senden.
- Standardmäßig lokal: Sitzungen, Speicherdateien, Konfiguration und Workspace liegen auf dem Gateway-Host
(
~/.openclaw+ Ihr Workspace-Verzeichnis). - Notwendigerweise remote: Nachrichten, die Sie an Modell-Provider (Anthropic/OpenAI/usw.) senden, gehen an deren APIs, und Chat-Plattformen (WhatsApp/Telegram/Slack/usw.) speichern Nachrichtendaten auf ihren Servern.
- Sie kontrollieren den Umfang: Bei lokalen Modellen bleiben Prompts auf Ihrem Computer, aber Channel- Traffic läuft weiterhin über die Server des Channels.
Verwandt: Agent-Workspace, Memory.
Wo speichert OpenClaw seine Daten?
Alles liegt unter $OPENCLAW_STATE_DIR (Standard: ~/.openclaw):
| Pfad | Zweck |
|---|---|
$OPENCLAW_STATE_DIR/openclaw.json |
Hauptkonfiguration (JSON5) |
$OPENCLAW_STATE_DIR/credentials/oauth.json |
Legacy-OAuth-Import (bei erster Verwendung in Auth-Profile kopiert) |
$OPENCLAW_STATE_DIR/agents/<agentId>/agent/auth-profiles.json |
Auth-Profile (OAuth, API-Schlüssel und optional keyRef/tokenRef) |
$OPENCLAW_STATE_DIR/secrets.json |
Optionale dateibasierte Secret-Payload für file SecretRef-Provider |
$OPENCLAW_STATE_DIR/agents/<agentId>/agent/auth.json |
Legacy-Kompatibilitätsdatei (statische api_key-Einträge bereinigt) |
$OPENCLAW_STATE_DIR/credentials/ |
Provider-Zustand (z. B. whatsapp/<accountId>/creds.json) |
$OPENCLAW_STATE_DIR/agents/ |
Agent-spezifischer Zustand (agentDir + Sitzungen) |
$OPENCLAW_STATE_DIR/agents/<agentId>/sessions/ |
Konversationsverlauf und Zustand (pro Agent) |
$OPENCLAW_STATE_DIR/agents/<agentId>/sessions/sessions.json |
Sitzungsmetadaten (pro Agent) |
Legacy-Pfad für einzelne Agents: ~/.openclaw/agent/* (migriert durch openclaw doctor).
Ihr Workspace (AGENTS.md, Speicherdateien, Skills usw.) ist separat und wird über agents.defaults.workspace konfiguriert (Standard: ~/.openclaw/workspace).
Wo sollten AGENTS.md / SOUL.md / USER.md / MEMORY.md liegen?
Diese Dateien liegen im Agent-Workspace, nicht in ~/.openclaw.
- Workspace (pro Agent):
AGENTS.md,SOUL.md,IDENTITY.md,USER.md,MEMORY.md,memory/YYYY-MM-DD.md, optionalHEARTBEAT.md. Die kleingeschriebene Root-Dateimemory.mdist nur Legacy-Reparatureingabe;openclaw doctor --fixkann sie inMEMORY.mdzusammenführen, wenn beide Dateien vorhanden sind. - Zustandsverzeichnis (
~/.openclaw): Konfiguration, Channel-/Provider-Zustand, Auth-Profile, Sitzungen, Logs und gemeinsame Skills (~/.openclaw/skills).
Der Standard-Workspace ist ~/.openclaw/workspace, konfigurierbar über:
{ agents: { defaults: { workspace: "~/.openclaw/workspace" } },}Wenn der Bot nach einem Neustart „vergisst“, prüfen Sie, ob der Gateway bei jedem Start denselben Workspace verwendet (und denken Sie daran: Der Remote-Modus verwendet den Workspace des Gateway-Hosts, nicht Ihren lokalen Laptop).
Tipp: Wenn Sie ein dauerhaftes Verhalten oder eine dauerhafte Präferenz möchten, bitten Sie den Bot, dies in AGENTS.md oder MEMORY.md zu schreiben, anstatt sich auf den Chatverlauf zu verlassen.
Siehe Agent-Workspace und Memory.
Empfohlene Backup-Strategie
Legen Sie Ihren Agent-Workspace in einem privaten Git-Repository ab und sichern Sie ihn an einem privaten Ort (zum Beispiel GitHub private). Das erfasst Speicher + AGENTS/SOUL/USER- Dateien und ermöglicht Ihnen, den „Geist“ des Assistenten später wiederherzustellen.
Committen Sie nichts unter ~/.openclaw (Anmeldedaten, Sitzungen, Token oder verschlüsselte Secret-Payloads).
Wenn Sie eine vollständige Wiederherstellung benötigen, sichern Sie sowohl den Workspace als auch das Zustandsverzeichnis
separat (siehe die Migrationsfrage oben).
Dokumentation: Agent-Workspace.
Wie deinstalliere ich OpenClaw vollständig?
Siehe die separate Anleitung: Deinstallation.
Können Agents außerhalb des Workspace arbeiten?
Ja. Der Workspace ist das Standard-cwd und der Speicheranker, keine feste Sandbox.
Relative Pfade werden innerhalb des Workspace aufgelöst, aber absolute Pfade können auf andere
Host-Speicherorte zugreifen, sofern Sandboxing nicht aktiviert ist. Wenn Sie Isolation benötigen, verwenden Sie
agents.defaults.sandbox oder Agent-spezifische Sandbox-Einstellungen. Wenn Sie
möchten, dass ein Repository das Standardarbeitsverzeichnis ist, setzen Sie den
workspace dieses Agents auf den Repository-Root. Das OpenClaw-Repository ist nur Quellcode; halten Sie den
Workspace getrennt, außer Sie möchten ausdrücklich, dass der Agent darin arbeitet.
Beispiel (Repository als Standard-cwd):
{ agents: { defaults: { workspace: "~/Projects/my-repo", }, },}Remote-Modus: Wo ist der Sitzungsspeicher?
Der Sitzungszustand gehört dem Gateway-Host. Wenn Sie im Remote-Modus sind, befindet sich der für Sie relevante Sitzungsspeicher auf der Remote-Maschine, nicht auf Ihrem lokalen Laptop. Siehe Sitzungsverwaltung.
Grundlagen der Konfiguration
Welches Format hat die Konfiguration? Wo befindet sie sich?
OpenClaw liest eine optionale JSON5-Konfiguration aus $OPENCLAW_CONFIG_PATH (Standard: ~/.openclaw/openclaw.json):
$OPENCLAW_CONFIG_PATHWenn die Datei fehlt, verwendet es relativ sichere Standardwerte (einschließlich eines Standard-Workspace von ~/.openclaw/workspace).
Ich habe gateway.bind: "lan" (oder "tailnet") gesetzt und jetzt lauscht nichts / die UI meldet nicht autorisiert
Nicht-loopback-Bindings erfordern einen gültigen Gateway-Auth-Pfad. In der Praxis bedeutet das:
- Shared-Secret-Authentifizierung: Token oder Passwort
gateway.auth.mode: "trusted-proxy"hinter einem korrekt konfigurierten identitätsbewussten Reverse-Proxy
{ gateway: { bind: "lan", auth: { mode: "token", token: "replace-me", }, },}Hinweise:
gateway.remote.token/.passwordaktivieren die lokale Gateway-Authentifizierung nicht von selbst.- Lokale Aufrufpfade können
gateway.remote.*nur als Fallback verwenden, wenngateway.auth.*nicht gesetzt ist. - Für Passwortauthentifizierung setzen Sie stattdessen
gateway.auth.mode: "password"plusgateway.auth.password(oderOPENCLAW_GATEWAY_PASSWORD). - Wenn
gateway.auth.token/gateway.auth.passwordexplizit über SecretRef konfiguriert und nicht aufgelöst ist, schlägt die Auflösung geschlossen fehl (keine Maskierung durch Remote-Fallback). - Shared-Secret-Control-UI-Setups authentifizieren über
connect.params.auth.tokenoderconnect.params.auth.password(in App-/UI-Einstellungen gespeichert). Identitätsführende Modi wie Tailscale Serve odertrusted-proxyverwenden stattdessen Request-Header. Vermeiden Sie Shared Secrets in URLs. - Bei
gateway.auth.mode: "trusted-proxy"erfordern Reverse-Proxys mit loopback auf demselben Host explizitgateway.auth.trustedProxy.allowLoopback = trueund einen loopback-Eintrag ingateway.trustedProxies.
Warum brauche ich jetzt ein Token auf localhost?
OpenClaw erzwingt standardmäßig Gateway-Authentifizierung, einschließlich loopback. Im normalen Standardpfad bedeutet das Token-Authentifizierung: Wenn kein expliziter Auth-Pfad konfiguriert ist, wird der Gateway-Start in den Token-Modus aufgelöst und erzeugt für diesen Start ein nur zur Laufzeit gültiges Token, sodass lokale WS-Clients sich authentifizieren müssen. Konfigurieren Sie gateway.auth.token, gateway.auth.password, OPENCLAW_GATEWAY_TOKEN oder OPENCLAW_GATEWAY_PASSWORD explizit, wenn Clients über Neustarts hinweg ein stabiles Secret benötigen. Das blockiert andere lokale Prozesse daran, den Gateway aufzurufen.
Wenn Sie einen anderen Auth-Pfad bevorzugen, können Sie explizit den Passwortmodus wählen (oder, für identitätsbewusste Reverse-Proxys, trusted-proxy). Wenn Sie wirklich offenes loopback möchten, setzen Sie gateway.auth.mode: "none" explizit in Ihrer Konfiguration. Doctor kann jederzeit ein Token für Sie erzeugen: openclaw doctor --generate-gateway-token.
Muss ich nach einer Konfigurationsänderung neu starten?
Der Gateway überwacht die Konfiguration und unterstützt Hot-Reload:
gateway.reload.mode: "hybrid"(Standard): sichere Änderungen per Hot-Apply anwenden, für kritische Änderungen neu startenhot,restart,offwerden ebenfalls unterstützt
Wie deaktiviere ich lustige CLI-Taglines?
Setzen Sie cli.banner.taglineMode in der Konfiguration:
{ cli: { banner: { taglineMode: "off", // random | default | off }, },}off: blendet Tagline-Text aus, behält aber die Banner-Titel-/Versionszeile bei.default: verwendet jedes MalAll your chats, one OpenClaw..random: rotierende lustige/saisonale Taglines (Standardverhalten).- Wenn Sie gar kein Banner möchten, setzen Sie die Umgebungsvariable
OPENCLAW_HIDE_BANNER=1.
Wie aktiviere ich Websuche (und Web-Abruf)?
web_fetch funktioniert ohne API-Schlüssel. web_search hängt von Ihrem ausgewählten
Provider ab:
- API-gestützte Provider wie Brave, Exa, Firecrawl, Gemini, Grok, Kimi, MiniMax Search, Perplexity und Tavily erfordern ihre normale API-Schlüssel-Einrichtung.
- Ollama Web Search ist schlüsselfrei, verwendet aber Ihren konfigurierten Ollama-Host und erfordert
ollama signin. - DuckDuckGo ist schlüsselfrei, ist aber eine inoffizielle HTML-basierte Integration.
- SearXNG ist schlüsselfrei/selbst gehostet; konfigurieren Sie
SEARXNG_BASE_URLoderplugins.entries.searxng.config.webSearch.baseUrl.
Empfohlen: Führen Sie openclaw configure --section web aus und wählen Sie einen Provider.
Umgebungsalternativen:
- Brave:
BRAVE_API_KEY - Exa:
EXA_API_KEY - Firecrawl:
FIRECRAWL_API_KEY - Gemini:
GEMINI_API_KEY - Grok:
XAI_API_KEY - Kimi:
KIMI_API_KEYoderMOONSHOT_API_KEY - MiniMax Search:
MINIMAX_CODE_PLAN_KEY,MINIMAX_CODING_API_KEYoderMINIMAX_API_KEY - Perplexity:
PERPLEXITY_API_KEYoderOPENROUTER_API_KEY - SearXNG:
SEARXNG_BASE_URL - Tavily:
TAVILY_API_KEY
{ plugins: { entries: { brave: { config: { webSearch: { apiKey: "BRAVE_API_KEY_HERE", }, }, }, }, }, tools: { web: { search: { enabled: true, provider: "brave", maxResults: 5, }, fetch: { enabled: true, provider: "firecrawl", // optional; omit for auto-detect }, }, },}Provider-spezifische Websuch-Konfiguration befindet sich jetzt unter plugins.entries.<plugin>.config.webSearch.*.
Veraltete Provider-Pfade unter tools.web.search.* werden aus Kompatibilitätsgründen vorübergehend noch geladen, sollten aber nicht für neue Konfigurationen verwendet werden.
Die Firecrawl-Web-Fetch-Fallback-Konfiguration befindet sich unter plugins.entries.firecrawl.config.webFetch.*.
Hinweise:
- Wenn Sie Allowlists verwenden, fügen Sie
web_search/web_fetch/x_searchodergroup:webhinzu. web_fetchist standardmäßig aktiviert (sofern nicht ausdrücklich deaktiviert).- Wenn
tools.web.fetch.providerweggelassen wird, erkennt OpenClaw automatisch den ersten einsatzbereiten Fetch-Fallback-Provider aus den verfügbaren Zugangsdaten. Der derzeit gebündelte Provider ist Firecrawl. - Daemons lesen Umgebungsvariablen aus
~/.openclaw/.env(oder aus der Service-Umgebung).
Dokumentation: Webtools.
config.apply hat meine Konfiguration gelöscht. Wie stelle ich sie wieder her und vermeide das?
config.apply ersetzt die gesamte Konfiguration. Wenn Sie ein partielles Objekt senden, wird alles
andere entfernt.
Die aktuelle OpenClaw-Version schützt vor vielen versehentlichen Überschreibungen:
- OpenClaw-eigene Konfigurationsschreibvorgänge validieren vor dem Schreiben die vollständige Konfiguration nach der Änderung.
- Ungültige oder destruktive OpenClaw-eigene Schreibvorgänge werden abgelehnt und als
openclaw.json.rejected.*gespeichert. - Wenn eine direkte Bearbeitung den Start oder Hot Reload beschädigt, schlägt der Gateway geschlossen fehl oder überspringt den Reload; er schreibt
openclaw.jsonnicht neu. openclaw doctor --fixist für Reparaturen zuständig und kann den letzten bekannten funktionierenden Stand wiederherstellen, während die abgelehnte Datei alsopenclaw.json.clobbered.*gespeichert wird.
Wiederherstellung:
- Prüfen Sie
openclaw logs --followaufInvalid config at,Config write rejected:oderconfig reload skipped (invalid config). - Prüfen Sie die neueste
openclaw.json.clobbered.*oderopenclaw.json.rejected.*neben der aktiven Konfiguration. - Führen Sie
openclaw config validateundopenclaw doctor --fixaus. - Kopieren Sie nur die beabsichtigten Schlüssel mit
openclaw config setoderconfig.patchzurück. - Wenn Sie keinen letzten bekannten funktionierenden Stand und keine abgelehnte Nutzlast haben, stellen Sie aus einem Backup wieder her, oder führen Sie
openclaw doctorerneut aus und konfigurieren Sie Kanäle/Modelle neu. - Wenn dies unerwartet war, melden Sie einen Fehler und fügen Sie Ihre letzte bekannte Konfiguration oder ein Backup bei.
- Ein lokaler Coding-Agent kann oft aus Logs oder Verlauf eine funktionierende Konfiguration rekonstruieren.
Vermeidung:
- Verwenden Sie
openclaw config setfür kleine Änderungen. - Verwenden Sie
openclaw configurefür interaktive Bearbeitungen. - Verwenden Sie zuerst
config.schema.lookup, wenn Sie sich bei einem genauen Pfad oder einer Feldstruktur nicht sicher sind; es gibt einen flachen Schemaknoten plus Zusammenfassungen der direkten untergeordneten Elemente für Drill-down zurück. - Verwenden Sie
config.patchfür partielle RPC-Bearbeitungen; verwenden Sieconfig.applynur für den vollständigen Austausch der Konfiguration. - Wenn Sie das nur für Owner vorgesehene Tool
gatewayaus einem Agent-Lauf verwenden, lehnt es weiterhin Schreibvorgänge auftools.exec.ask/tools.exec.securityab (einschließlich veraltetertools.bash.*-Aliasse, die auf dieselben geschützten Exec-Pfade normalisiert werden).
Dokumentation: Konfiguration, Konfigurieren, Gateway-Fehlerbehebung, Doctor.
Wie führe ich einen zentralen Gateway mit spezialisierten Workern über mehrere Geräte hinweg aus?
Das gängige Muster ist ein Gateway (z. B. Raspberry Pi) plus Nodes und Agenten:
- Gateway (zentral): verwaltet Kanäle (Signal/WhatsApp), Routing und Sitzungen.
- Nodes (Geräte): Macs/iOS/Android verbinden sich als Peripheriegeräte und stellen lokale Tools bereit (
system.run,canvas,camera). - Agenten (Worker): separate Gehirne/Arbeitsbereiche für spezielle Rollen (z. B. „Hetzner-Ops“, „Persönliche Daten“).
- Sub-Agenten: starten Hintergrundarbeit von einem Hauptagenten aus, wenn Sie Parallelität möchten.
- TUI: verbindet sich mit dem Gateway und wechselt zwischen Agenten/Sitzungen.
Dokumentation: Nodes, Remote-Zugriff, Multi-Agent-Routing, Sub-Agenten, TUI.
Kann der OpenClaw-Browser headless ausgeführt werden?
Ja. Das ist eine Konfigurationsoption:
{ browser: { headless: true }, agents: { defaults: { sandbox: { browser: { headless: true } }, }, },}Standardwert ist false (mit sichtbarem Browser). Der Headless-Modus löst auf manchen Websites eher Anti-Bot-Prüfungen aus. Siehe Browser.
Der Headless-Modus verwendet dieselbe Chromium-Engine und funktioniert für die meisten Automatisierungen (Formulare, Klicks, Scraping, Logins). Die Hauptunterschiede:
- Kein sichtbares Browserfenster (verwenden Sie Screenshots, wenn Sie visuelle Ausgabe benötigen).
- Manche Websites sind im Headless-Modus strenger gegenüber Automatisierung (CAPTCHAs, Anti-Bot). X/Twitter blockiert beispielsweise häufig Headless-Sitzungen.
Wie verwende ich Brave für die Browsersteuerung?
Setzen Sie browser.executablePath auf Ihre Brave-Binärdatei (oder einen anderen Chromium-basierten Browser) und starten Sie den Gateway neu.
Siehe die vollständigen Konfigurationsbeispiele unter Browser.
Remote-Gateways und Nodes
Wie werden Befehle zwischen Telegram, dem Gateway und Nodes weitergegeben?
Telegram-Nachrichten werden vom Gateway verarbeitet. Der Gateway führt den Agenten aus und ruft erst dann Nodes über den Gateway WebSocket auf, wenn ein Node-Tool benötigt wird:
Telegram → Gateway → Agent → node.* → Node → Gateway → Telegram
Nodes sehen keinen eingehenden Provider-Traffic; sie erhalten nur Node-RPC-Aufrufe.
Wie kann mein Agent auf meinen Computer zugreifen, wenn der Gateway remote gehostet wird?
Kurzfassung: Koppeln Sie Ihren Computer als Node. Der Gateway läuft anderswo, kann aber
node.*-Tools (Bildschirm, Kamera, System) auf Ihrer lokalen Maschine über den Gateway WebSocket aufrufen.
Typische Einrichtung:
-
Führen Sie den Gateway auf dem Always-on-Host aus (VPS/Home-Server).
-
Bringen Sie den Gateway-Host und Ihren Computer in dasselbe Tailnet.
-
Stellen Sie sicher, dass der Gateway-WS erreichbar ist (Tailnet-Bindung oder SSH-Tunnel).
-
Öffnen Sie die macOS-App lokal und verbinden Sie sich im Modus Remote über SSH (oder direktes Tailnet), damit sie sich als Node registrieren kann.
-
Genehmigen Sie den Node auf dem Gateway:
bash openclaw devices listopenclaw devices approve <requestId>
Es ist keine separate TCP-Bridge erforderlich; Nodes verbinden sich über den Gateway WebSocket.
Sicherheitshinweis: Das Koppeln eines macOS-Node erlaubt system.run auf dieser Maschine. Koppeln Sie
nur Geräte, denen Sie vertrauen, und lesen Sie Sicherheit.
Dokumentation: Nodes, Gateway-Protokoll, macOS-Remote-Modus, Sicherheit.
Tailscale ist verbunden, aber ich erhalte keine Antworten. Was jetzt?
Prüfen Sie die Grundlagen:
- Gateway läuft:
openclaw gateway status - Gateway-Zustand:
openclaw status - Kanalzustand:
openclaw channels status
Prüfen Sie anschließend Authentifizierung und Routing:
- Wenn Sie Tailscale Serve verwenden, stellen Sie sicher, dass
gateway.auth.allowTailscalekorrekt gesetzt ist. - Wenn Sie sich über einen SSH-Tunnel verbinden, bestätigen Sie, dass der lokale Tunnel aktiv ist und auf den richtigen Port zeigt.
- Bestätigen Sie, dass Ihre Allowlists (DM oder Gruppe) Ihr Konto enthalten.
Dokumentation: Tailscale, Remote-Zugriff, Kanäle.
Können zwei OpenClaw-Instanzen miteinander sprechen (lokal + VPS)?
Ja. Es gibt keine eingebaute „Bot-zu-Bot“-Bridge, aber Sie können dies auf ein paar zuverlässige Arten verbinden:
Am einfachsten: Verwenden Sie einen normalen Chatkanal, auf den beide Bots zugreifen können (Telegram/Slack/WhatsApp). Lassen Sie Bot A eine Nachricht an Bot B senden, und lassen Sie Bot B dann wie gewohnt antworten.
CLI-Bridge (generisch): Führen Sie ein Skript aus, das den anderen Gateway mit
openclaw agent --message ... --deliver aufruft und dabei auf einen Chat zielt, in dem der andere Bot
lauscht. Wenn ein Bot auf einem Remote-VPS läuft, richten Sie Ihre CLI über SSH/Tailscale auf diesen Remote-Gateway
aus (siehe Remote-Zugriff).
Beispielmuster (von einer Maschine aus ausführen, die den Ziel-Gateway erreichen kann):
openclaw agent --message "Hello from local bot" --deliver --channel telegram --reply-to <chat-id>Tipp: Fügen Sie eine Schutzregel hinzu, damit die beiden Bots nicht endlos in einer Schleife laufen (nur Erwähnungen, Kanal- Allowlists oder eine Regel „nicht auf Bot-Nachrichten antworten“).
Dokumentation: Remote-Zugriff, Agent-CLI, Agent-Senden.
Benötige ich separate VPSes für mehrere Agenten?
Nein. Ein Gateway kann mehrere Agenten hosten, jeweils mit eigenem Arbeitsbereich, eigenen Modell-Standardwerten und eigenem Routing. Das ist die normale Einrichtung und deutlich günstiger und einfacher, als einen VPS pro Agent zu betreiben.
Verwenden Sie separate VPSes nur, wenn Sie harte Isolation (Sicherheitsgrenzen) oder sehr unterschiedliche Konfigurationen benötigen, die Sie nicht teilen möchten. Andernfalls verwenden Sie einen Gateway und mehrere Agenten oder Sub-Agenten.
Gibt es einen Vorteil, einen Node auf meinem persönlichen Laptop statt SSH von einem VPS aus zu verwenden?
Ja – Nodes sind der bevorzugte Weg, um Ihren Laptop von einem Remote-Gateway aus zu erreichen, und sie ermöglichen mehr als Shell-Zugriff. Der Gateway läuft auf macOS/Linux (Windows über WSL2) und ist leichtgewichtig (ein kleiner VPS oder eine Raspberry-Pi-Klasse reicht aus; 4 GB RAM sind reichlich), daher ist eine übliche Einrichtung ein Always-on-Host plus Ihr Laptop als Node.
- Kein eingehendes SSH erforderlich. Nodes stellen eine ausgehende Verbindung zum Gateway WebSocket her und verwenden Gerätekopplung.
- Sicherere Ausführungskontrollen.
system.runwird auf diesem Laptop durch Node-Allowlists/Genehmigungen abgesichert. - Mehr Geräte-Tools. Nodes stellen zusätzlich zu
system.runauchcanvas,cameraundscreenbereit. - Lokale Browserautomatisierung. Lassen Sie den Gateway auf einem VPS, führen Sie Chrome aber lokal über einen Node-Host auf dem Laptop aus, oder hängen Sie sich über Chrome MCP an lokales Chrome auf dem Host an.
SSH ist für Ad-hoc-Shell-Zugriff in Ordnung, aber Nodes sind für laufende Agent-Workflows und Geräteautomatisierung einfacher.
Führen Nodes einen Gateway-Dienst aus?
Nein. Pro Host sollte nur ein Gateway laufen, außer Sie betreiben absichtlich isolierte Profile (siehe Mehrere Gateways). Nodes sind Peripheriegeräte, die sich mit dem Gateway verbinden (iOS-/Android-Nodes oder macOS-„Node-Modus“ in der Menüleisten-App). Für Headless-Node- Hosts und CLI-Steuerung siehe Node-Host-CLI.
Für Änderungen an gateway, discovery und gehosteten Plugin-Oberflächen ist ein vollständiger Neustart erforderlich.
Gibt es eine API-/RPC-Möglichkeit, Konfiguration anzuwenden?
Ja.
config.schema.lookup: einen Config-Teilbaum mit seinem flachen Schema-Knoten, passendem UI-Hinweis und unmittelbaren Zusammenfassungen der untergeordneten Elemente vor dem Schreiben prüfenconfig.get: aktuellen Snapshot + Hash abrufenconfig.patch: sichere Teilaktualisierung (für die meisten RPC-Bearbeitungen bevorzugt); lädt wenn möglich im laufenden Betrieb neu und startet neu, wenn erforderlichconfig.apply: vollständige Config validieren + ersetzen; lädt wenn möglich im laufenden Betrieb neu und startet neu, wenn erforderlich- Das nur für Owner verfügbare Runtime-Tool
gatewayverweigert weiterhin das Umschreiben vontools.exec.ask/tools.exec.security; älteretools.bash.*-Aliasse werden auf dieselben geschützten Exec-Pfade normalisiert
Minimale sinnvolle Config für eine Erstinstallation
{ agents: { defaults: { workspace: "~/.openclaw/workspace" } }, channels: { whatsapp: { allowFrom: ["+15555550123"] } },}Dies legt Ihren Workspace fest und schränkt ein, wer den Bot auslösen kann.
Wie richte ich Tailscale auf einem VPS ein und verbinde mich von meinem Mac aus?
Minimale Schritte:
-
Auf dem VPS installieren + anmelden
bash curl -fsSL https://tailscale.com/install.sh | shsudo tailscale up -
Auf Ihrem Mac installieren + anmelden
- Verwenden Sie die Tailscale-App und melden Sie sich beim selben Tailnet an.
-
MagicDNS aktivieren (empfohlen)
- Aktivieren Sie MagicDNS in der Tailscale-Admin-Konsole, damit der VPS einen stabilen Namen hat.
-
Den Tailnet-Hostnamen verwenden
- SSH:
ssh [email protected] - Gateway WS:
ws://your-vps.tailnet-xxxx.ts.net:18789
- SSH:
Wenn Sie die Control UI ohne SSH möchten, verwenden Sie Tailscale Serve auf dem VPS:
openclaw gateway --tailscale serveDadurch bleibt das Gateway an loopback gebunden und HTTPS wird über Tailscale bereitgestellt. Siehe Tailscale.
Wie verbinde ich einen Mac-Node mit einem entfernten Gateway (Tailscale Serve)?
Serve stellt die Gateway Control UI + WS bereit. Nodes verbinden sich über denselben Gateway-WS-Endpunkt.
Empfohlene Einrichtung:
-
Stellen Sie sicher, dass VPS + Mac im selben Tailnet sind.
-
Verwenden Sie die macOS-App im Remote-Modus (das SSH-Ziel kann der Tailnet-Hostname sein). Die App tunnelt den Gateway-Port und verbindet sich als Node.
-
Genehmigen Sie den Node am Gateway:
bash openclaw devices listopenclaw devices approve <requestId>
Dokumentation: Gateway-Protokoll, Erkennung, macOS-Remote-Modus.
Sollte ich auf einem zweiten Laptop installieren oder einfach einen Node hinzufügen?
Wenn Sie auf dem zweiten Laptop nur lokale Tools (Bildschirm/Kamera/Exec) benötigen, fügen Sie ihn als Node hinzu. Dadurch bleibt es bei einem einzelnen Gateway und doppelte Config wird vermieden. Lokale Node-Tools sind derzeit nur für macOS verfügbar, aber wir planen, sie auf andere Betriebssysteme auszuweiten.
Installieren Sie ein zweites Gateway nur, wenn Sie strikte Isolation oder zwei vollständig getrennte Bots benötigen.
Dokumentation: Nodes, Nodes CLI, Mehrere Gateways.
Umgebungsvariablen und Laden von .env
Wie lädt OpenClaw Umgebungsvariablen?
OpenClaw liest Umgebungsvariablen aus dem übergeordneten Prozess (Shell, launchd/systemd, CI usw.) und lädt zusätzlich:
.envaus dem aktuellen Arbeitsverzeichnis- eine globale Fallback-
.envaus~/.openclaw/.env(auch$OPENCLAW_STATE_DIR/.envgenannt)
Keine der .env-Dateien überschreibt vorhandene Umgebungsvariablen.
Sie können auch Inline-Umgebungsvariablen in der Config definieren (werden nur angewendet, wenn sie in der Prozessumgebung fehlen):
{ env: { OPENROUTER_API_KEY: "sk-or-...", vars: { GROQ_API_KEY: "gsk-..." }, },}Die vollständige Rangfolge und Quellen finden Sie unter /Umgebung.
Ich habe das Gateway über den Dienst gestartet und meine Umgebungsvariablen sind verschwunden. Was jetzt?
Zwei häufige Lösungen:
- Legen Sie die fehlenden Schlüssel in
~/.openclaw/.envab, damit sie auch dann aufgenommen werden, wenn der Dienst Ihre Shell-Umgebung nicht erbt. - Aktivieren Sie den Shell-Import (optionaler Komfort):
{ env: { shellEnv: { enabled: true, timeoutMs: 15000, }, },}Dadurch wird Ihre Login-Shell ausgeführt und nur fehlende erwartete Schlüssel werden importiert (niemals überschrieben). Entsprechende Umgebungsvariablen:
OPENCLAW_LOAD_SHELL_ENV=1, OPENCLAW_SHELL_ENV_TIMEOUT_MS=15000.
Ich habe COPILOT_GITHUB_TOKEN gesetzt, aber der Modellstatus zeigt "Shell env: off." Warum?
openclaw models status meldet, ob der Shell-Umgebungsimport aktiviert ist. "Shell env: off"
bedeutet nicht, dass Ihre Umgebungsvariablen fehlen - es bedeutet nur, dass OpenClaw
Ihre Login-Shell nicht automatisch lädt.
Wenn das Gateway als Dienst (launchd/systemd) ausgeführt wird, erbt es Ihre Shell- Umgebung nicht. Beheben Sie dies mit einer dieser Optionen:
-
Legen Sie das Token in
~/.openclaw/.envab:Code COPILOT_GITHUB_TOKEN=... -
Oder aktivieren Sie den Shell-Import (
env.shellEnv.enabled: true). -
Oder fügen Sie es dem
env-Block Ihrer Config hinzu (wird nur angewendet, wenn es fehlt).
Starten Sie dann das Gateway neu und prüfen Sie erneut:
openclaw models statusCopilot-Tokens werden aus COPILOT_GITHUB_TOKEN gelesen (auch GH_TOKEN / GITHUB_TOKEN).
Siehe /Konzepte/Modell-Provider und /Umgebung.
Sitzungen und mehrere Chats
Wie beginne ich eine neue Unterhaltung?
Senden Sie /new oder /reset als eigenständige Nachricht. Siehe Sitzungsverwaltung.
Werden Sitzungen automatisch zurückgesetzt, wenn ich nie /new sende?
Sitzungen können nach session.idleMinutes ablaufen, dies ist jedoch standardmäßig deaktiviert (Standardwert 0).
Setzen Sie den Wert auf einen positiven Wert, um Ablauf bei Inaktivität zu aktivieren. Wenn aktiviert, startet die nächste
Nachricht nach der Inaktivitätsperiode eine neue Sitzungs-ID für diesen Chat-Schlüssel.
Dies löscht keine Transkripte - es startet nur eine neue Sitzung.
{ session: { idleMinutes: 240, },}Gibt es eine Möglichkeit, ein Team aus OpenClaw-Instanzen zu erstellen (ein CEO und viele Agenten)?
Ja, über Multi-Agent-Routing und Sub-Agents. Sie können einen Koordinator- Agenten und mehrere Arbeitsagenten mit eigenen Workspaces und Modellen erstellen.
Dennoch sollte dies am besten als unterhaltsames Experiment betrachtet werden. Es verbraucht viele Tokens und ist oft weniger effizient als ein Bot mit getrennten Sitzungen. Das typische Modell, das wir vorsehen, ist ein Bot, mit dem Sie sprechen, mit verschiedenen Sitzungen für parallele Arbeit. Dieser Bot kann bei Bedarf auch Sub-Agents starten.
Dokumentation: Multi-Agent-Routing, Sub-Agents, Agenten-CLI.
Warum wurde der Kontext mitten in der Aufgabe gekürzt? Wie verhindere ich das?
Der Sitzungskontext ist durch das Modellfenster begrenzt. Lange Chats, große Tool-Ausgaben oder viele Dateien können Compaction oder Kürzung auslösen.
Das hilft:
- Bitten Sie den Bot, den aktuellen Stand zusammenzufassen und in eine Datei zu schreiben.
- Verwenden Sie
/compactvor langen Aufgaben und/new, wenn Sie das Thema wechseln. - Bewahren Sie wichtigen Kontext im Workspace auf und bitten Sie den Bot, ihn erneut zu lesen.
- Verwenden Sie Sub-Agents für lange oder parallele Arbeit, damit der Hauptchat kleiner bleibt.
- Wählen Sie ein Modell mit einem größeren Kontextfenster, wenn dies häufig passiert.
Wie setze ich OpenClaw vollständig zurück, behalte es aber installiert?
Verwenden Sie den Reset-Befehl:
openclaw resetVollständiger nicht interaktiver Reset:
openclaw reset --scope full --yes --non-interactiveFühren Sie dann das Setup erneut aus:
openclaw onboard --install-daemonHinweise:
- Onboarding bietet auch Reset an, wenn eine vorhandene Konfiguration erkannt wird. Siehe Onboarding (CLI).
- Wenn Sie Profile verwendet haben (
--profile/OPENCLAW_PROFILE), setzen Sie jedes Statusverzeichnis zurück (Standardwerte sind~/.openclaw-<profile>). - Dev-Reset:
openclaw gateway --dev --reset(nur Dev; löscht Dev-Konfiguration + Anmeldedaten + Sitzungen + Workspace).
Ich erhalte Fehler vom Typ "context too large" - wie setze ich zurück oder komprimiere ich?
Verwenden Sie eine dieser Optionen:
-
Kompaktieren (behält die Unterhaltung bei, fasst aber ältere Turns zusammen):
Code /compactoder
/compact <instructions>, um die Zusammenfassung zu steuern. -
Reset (neue Sitzungs-ID für denselben Chat-Schlüssel):
Code /new/reset
Wenn es weiterhin passiert:
- Aktivieren oder justieren Sie Sitzungsbereinigung (
agents.defaults.contextPruning), um alte Tool-Ausgaben zu kürzen. - Verwenden Sie ein Modell mit einem größeren Kontextfenster.
Dokumentation: Compaction, Sitzungsbereinigung, Sitzungsverwaltung.
Warum sehe ich "LLM request rejected: messages.content.tool_use.input field required"?
Dies ist ein Provider-Validierungsfehler: Das Modell hat einen tool_use-Block ohne das erforderliche
input ausgegeben. Das bedeutet normalerweise, dass der Sitzungsverlauf veraltet oder beschädigt ist (oft nach langen Threads
oder einer Tool-/Schemaänderung).
Behebung: Starten Sie mit /new eine frische Sitzung (als eigenständige Nachricht).
Warum erhalte ich alle 30 Minuten Heartbeat-Nachrichten?
Heartbeats laufen standardmäßig alle 30m (1h bei OAuth-Authentifizierung). Passen Sie sie an oder deaktivieren Sie sie:
{ agents: { defaults: { heartbeat: { every: "2h", // or "0m" to disable }, }, },}Wenn HEARTBEAT.md existiert, aber praktisch leer ist (nur Leerzeilen und Markdown-
Überschriften wie # Heading), überspringt OpenClaw den Heartbeat-Lauf, um API-Aufrufe zu sparen.
Wenn die Datei fehlt, läuft der Heartbeat trotzdem und das Modell entscheidet, was zu tun ist.
Agentenspezifische Überschreibungen verwenden agents.list[].heartbeat. Dokumentation: Heartbeat.
Muss ich einem WhatsApp-Gruppenchat ein "Bot-Konto" hinzufügen?
Nein. OpenClaw läuft über Ihr eigenes Konto. Wenn Sie also in der Gruppe sind, kann OpenClaw sie sehen.
Standardmäßig sind Gruppenantworten blockiert, bis Sie Absender erlauben (groupPolicy: "allowlist").
Wenn nur Sie Gruppenantworten auslösen können sollen:
{ channels: { whatsapp: { groupPolicy: "allowlist", groupAllowFrom: ["+15551234567"], }, },}Wie erhalte ich die JID einer WhatsApp-Gruppe?
Option 1 (am schnellsten): Logs verfolgen und eine Testnachricht in der Gruppe senden:
openclaw logs --follow --jsonSuchen Sie nach chatId (oder from), das auf @g.us endet, zum Beispiel:
[email protected].
Option 2 (wenn bereits konfiguriert/auf der Allowlist): Gruppen aus der Konfiguration auflisten:
openclaw directory groups list --channel whatsappDokumentation: WhatsApp, Verzeichnis, Logs.
Warum antwortet OpenClaw nicht in einer Gruppe?
Zwei häufige Ursachen:
- Mention-Gating ist aktiviert (Standard). Sie müssen den Bot @erwähnen (oder
mentionPatternserfüllen). - Sie haben
channels.whatsapp.groupsohne"*"konfiguriert und die Gruppe steht nicht auf der Allowlist.
Siehe Gruppen und Gruppennachrichten.
Teilen Gruppen/Threads den Kontext mit Direktnachrichten?
Direkte Chats werden standardmäßig zur Hauptsitzung zusammengeführt. Gruppen/Kanäle haben eigene Sitzungsschlüssel, und Telegram-Themen / Discord-Threads sind separate Sitzungen. Siehe Gruppen und Gruppennachrichten.
Wie viele Arbeitsbereiche und Agenten kann ich erstellen?
Keine festen Limits. Dutzende (sogar Hunderte) sind in Ordnung, achten Sie aber auf:
- Speicherplatzwachstum: Sitzungen + Transkripte liegen unter
~/.openclaw/agents/<agentId>/sessions/. - Token-Kosten: Mehr Agenten bedeuten mehr gleichzeitige Modellnutzung.
- Betriebsaufwand: Auth-Profile, Arbeitsbereiche und Kanal-Routing pro Agent.
Tipps:
- Behalten Sie pro Agent einen aktiven Arbeitsbereich bei (
agents.defaults.workspace). - Bereinigen Sie alte Sitzungen (JSONL oder Store-Einträge löschen), wenn der Speicherplatzverbrauch wächst.
- Verwenden Sie
openclaw doctor, um verwaiste Arbeitsbereiche und Profilabweichungen zu finden.
Kann ich mehrere Bots oder Chats gleichzeitig ausführen (Slack), und wie sollte ich das einrichten?
Ja. Verwenden Sie Multi-Agent-Routing, um mehrere isolierte Agenten auszuführen und eingehende Nachrichten nach Kanal/Konto/Peer weiterzuleiten. Slack wird als Kanal unterstützt und kann bestimmten Agenten zugeordnet werden.
Browser-Zugriff ist leistungsfähig, aber bedeutet nicht, dass Automatisierung „alles tun kann, was ein Mensch kann“ - Anti-Bot-Maßnahmen, CAPTCHAs und MFA können Automatisierung weiterhin blockieren. Für die zuverlässigste Browser-Steuerung verwenden Sie lokales Chrome MCP auf dem Host oder CDP auf der Maschine, die den Browser tatsächlich ausführt.
Empfohlene Einrichtung:
- Immer aktiver Gateway-Host (VPS/Mac mini).
- Ein Agent pro Rolle (Bindungen).
- Slack-Kanal/Kanäle, die diesen Agenten zugeordnet sind.
- Lokaler Browser über Chrome MCP oder bei Bedarf über einen Node.
Docs: Multi-Agent-Routing, Slack, Browser, Nodes.
Modelle, Failover und Auth-Profile
Modell-Fragen und -Antworten - Standardwerte, Auswahl, Aliasse, Wechsel, Failover, Auth-Profile - finden Sie in den Modell-FAQ.
Gateway: Ports, „läuft bereits“ und Remote-Modus
Welchen Port verwendet der Gateway?
gateway.port steuert den einzelnen multiplexierten Port für WebSocket + HTTP (Control UI, Hooks usw.).
Priorität:
--port > OPENCLAW_GATEWAY_PORT > gateway.port > default 18789Warum sagt openclaw gateway status „Runtime: running“, aber „Connectivity probe: failed“?
Weil „running“ die Sicht des Supervisors ist (launchd/systemd/schtasks). Die Verbindungsprüfung ist die CLI, die tatsächlich eine Verbindung zum Gateway-WebSocket herstellt.
Verwenden Sie openclaw gateway status und verlassen Sie sich auf diese Zeilen:
Probe target:(die URL, die die Prüfung tatsächlich verwendet hat)Listening:(was tatsächlich auf dem Port gebunden ist)Last gateway error:(häufige Ursache, wenn der Prozess lebt, der Port aber nicht lauscht)
Warum zeigt openclaw gateway status unterschiedliche Werte für „Config (cli)“ und „Config (service)“?
Sie bearbeiten eine Konfigurationsdatei, während der Dienst eine andere verwendet (häufig eine Abweichung bei --profile / OPENCLAW_STATE_DIR).
Behebung:
openclaw gateway install --forceFühren Sie dies mit demselben --profile / derselben Umgebung aus, die der Dienst verwenden soll.
Was bedeutet „another gateway instance is already listening“?
OpenClaw erzwingt eine Runtime-Sperre, indem der WebSocket-Listener sofort beim Start gebunden wird (Standard ws://127.0.0.1:18789). Wenn die Bindung mit EADDRINUSE fehlschlägt, wird GatewayLockError ausgelöst, was anzeigt, dass bereits eine andere Instanz lauscht.
Behebung: Stoppen Sie die andere Instanz, geben Sie den Port frei oder starten Sie mit openclaw gateway --port <port>.
Wie führe ich OpenClaw im Remote-Modus aus (Client verbindet sich mit einem Gateway an anderer Stelle)?
Setzen Sie gateway.mode: "remote" und verweisen Sie auf eine Remote-WebSocket-URL, optional mit Remote-Anmeldedaten über ein gemeinsames Secret:
{ gateway: { mode: "remote", remote: { url: "ws://gateway.tailnet:18789", token: "your-token", password: "your-password", }, },}Hinweise:
openclaw gatewaystartet nur, wenngateway.modelocalist (oder Sie das Override-Flag übergeben).- Die macOS-App überwacht die Konfigurationsdatei und wechselt live den Modus, wenn sich diese Werte ändern.
gateway.remote.token/.passwordsind nur clientseitige Remote-Anmeldedaten; sie aktivieren für sich genommen keine lokale Gateway-Authentifizierung.
Die Control UI sagt „unauthorized“ (oder verbindet sich ständig neu). Was nun?
Ihr Gateway-Authentifizierungspfad und die Authentifizierungsmethode der UI stimmen nicht überein.
Fakten (aus dem Code):
- Die Control UI behält das Token in
sessionStoragefür die aktuelle Browser-Tab-Sitzung und die ausgewählte Gateway-URL, sodass Aktualisierungen im selben Tab weiter funktionieren, ohne langlebige localStorage-Token-Persistenz wiederherzustellen. - Bei
AUTH_TOKEN_MISMATCHkönnen vertrauenswürdige Clients einen begrenzten Wiederholungsversuch mit einem zwischengespeicherten Geräte-Token versuchen, wenn der Gateway Wiederholungshinweise zurückgibt (canRetryWithDeviceToken=true,recommendedNextStep=retry_with_device_token). - Dieser Wiederholungsversuch mit zwischengespeichertem Token verwendet jetzt die zwischengespeicherten genehmigten Scopes wieder, die mit dem Geräte-Token gespeichert sind. Aufrufer mit explizitem
deviceToken/ explizitenscopesbehalten weiterhin ihr angefordertes Scope-Set, anstatt zwischengespeicherte Scopes zu erben. - Außerhalb dieses Wiederholungspfads gilt bei der Verbindungs-Authentifizierung folgende Priorität: zuerst explizites gemeinsames Token/Passwort, dann explizites
deviceToken, dann gespeichertes Geräte-Token, dann Bootstrap-Token. - Bootstrap-Token-Scope-Prüfungen sind rollenpräfixiert. Die integrierte Bootstrap-Operator-Allowlist erfüllt nur Operator-Anfragen; Node- oder andere Nicht-Operator-Rollen benötigen weiterhin Scopes unter ihrem eigenen Rollenpräfix.
Behebung:
- Am schnellsten:
openclaw dashboard(gibt die Dashboard-URL aus + kopiert sie, versucht sie zu öffnen; zeigt bei Headless-Systemen einen SSH-Hinweis). - Wenn Sie noch kein Token haben:
openclaw doctor --generate-gateway-token. - Bei Remote-Nutzung zuerst tunneln:
ssh -N -L 18789:127.0.0.1:18789 user@host, dannhttp://127.0.0.1:18789/öffnen. - Shared-Secret-Modus: Setzen Sie
gateway.auth.token/OPENCLAW_GATEWAY_TOKENodergateway.auth.password/OPENCLAW_GATEWAY_PASSWORDund fügen Sie dann das passende Secret in den Einstellungen der Control UI ein. - Tailscale-Serve-Modus: Stellen Sie sicher, dass
gateway.auth.allowTailscaleaktiviert ist und Sie die Serve-URL öffnen, nicht eine rohe local loopback-/tailnet-URL, die Tailscale-Identitätsheader umgeht. - Trusted-Proxy-Modus: Stellen Sie sicher, dass Sie über den konfigurierten identitätsbewussten Proxy kommen, nicht über eine rohe Gateway-URL. local loopback-Proxys auf demselben Host benötigen außerdem
gateway.auth.trustedProxy.allowLoopback = true. - Wenn die Abweichung nach dem einen Wiederholungsversuch bestehen bleibt, rotieren/genehmigen Sie das gekoppelte Geräte-Token erneut:
openclaw devices listopenclaw devices rotate --device <id> --role operator
- Wenn dieser Rotationsaufruf meldet, dass er verweigert wurde, prüfen Sie zwei Dinge:
- Sitzungen gekoppelter Geräte können nur ihr eigenes Gerät rotieren, sofern sie nicht auch
operator.adminhaben - explizite
--scope-Werte dürfen die aktuellen Operator-Scopes des Aufrufers nicht überschreiten
- Sitzungen gekoppelter Geräte können nur ihr eigenes Gerät rotieren, sofern sie nicht auch
- Weiterhin blockiert? Führen Sie
openclaw status --allaus und folgen Sie Fehlerbehebung. Siehe Dashboard für Authentifizierungsdetails.
Ich habe gateway.bind auf tailnet gesetzt, aber es kann nicht binden und nichts lauscht
Die tailnet-Bindung wählt eine Tailscale-IP aus Ihren Netzwerkschnittstellen (100.64.0.0/10). Wenn die Maschine nicht in Tailscale ist (oder die Schnittstelle ausgefallen ist), gibt es nichts, woran gebunden werden kann.
Behebung:
- Starten Sie Tailscale auf diesem Host (damit er eine 100.x-Adresse hat), oder
- wechseln Sie zu
gateway.bind: "loopback"/"lan".
Hinweis: tailnet ist explizit. auto bevorzugt loopback; verwenden Sie gateway.bind: "tailnet", wenn Sie eine reine tailnet-Bindung wünschen.
Kann ich mehrere Gateways auf demselben Host ausführen?
Normalerweise nein - ein Gateway kann mehrere Messaging-Kanäle und Agenten ausführen. Verwenden Sie mehrere Gateways nur, wenn Sie Redundanz (z. B. Rettungs-Bot) oder harte Isolation benötigen.
Ja, aber Sie müssen isolieren:
OPENCLAW_CONFIG_PATH(Konfiguration pro Instanz)OPENCLAW_STATE_DIR(Status pro Instanz)agents.defaults.workspace(Arbeitsbereichsisolation)gateway.port(eindeutige Ports)
Schnelle Einrichtung (empfohlen):
- Verwenden Sie
openclaw --profile <name> ...pro Instanz (erstellt automatisch~/.openclaw-<name>). - Setzen Sie in jeder Profilkonfiguration einen eindeutigen
gateway.port(oder übergeben Sie bei manuellen Läufen--port). - Installieren Sie einen Dienst pro Profil:
openclaw --profile <name> gateway install.
Profile hängen außerdem Suffixe an Dienstnamen an (ai.openclaw.<profile>; Legacy com.openclaw.*, openclaw-gateway-<profile>.service, OpenClaw Gateway (<profile>)).
Vollständige Anleitung: Mehrere Gateways.
Was bedeutet „invalid handshake“ / Code 1008?
Der Gateway ist ein WebSocket-Server und erwartet als allererste Nachricht
einen connect-Frame. Wenn er etwas anderes empfängt, schließt er die Verbindung
mit Code 1008 (Richtlinienverstoß).
Häufige Ursachen:
- Sie haben die HTTP-URL in einem Browser geöffnet (
http://...) statt in einem WS-Client. - Sie haben den falschen Port oder Pfad verwendet.
- Ein Proxy oder Tunnel hat Auth-Header entfernt oder eine Nicht-Gateway-Anfrage gesendet.
Schnelle Behebungen:
- Verwenden Sie die WS-URL:
ws://<host>:18789(oderwss://...bei HTTPS). - Öffnen Sie den WS-Port nicht in einem normalen Browser-Tab.
- Wenn Authentifizierung aktiviert ist, geben Sie Token/Passwort im
connect-Frame an.
Wenn Sie die CLI oder TUI verwenden, sollte die URL so aussehen:
openclaw tui --url ws://<host>:18789 --token <token>Protokolldetails: Gateway-Protokoll.
Protokollierung und Debugging
Wo sind die Logs?
Datei-Logs (strukturiert):
/tmp/openclaw/openclaw-YYYY-MM-DD.logSie können über logging.file einen stabilen Pfad festlegen. Die Datei-Logstufe wird durch logging.level gesteuert. Die Konsolenausführlichkeit wird durch --verbose und logging.consoleLevel gesteuert.
Schnellstes Log-Tailing:
openclaw logs --followDienst-/Supervisor-Logs (wenn der Gateway über launchd/systemd ausgeführt wird):
- macOS:
$OPENCLAW_STATE_DIR/logs/gateway.logundgateway.err.log(Standard:~/.openclaw/logs/...; Profile verwenden~/.openclaw-<profile>/logs/...) - Linux:
journalctl --user -u openclaw-gateway[-<profile>].service -n 200 --no-pager - Windows:
schtasks /Query /TN "OpenClaw Gateway (<profile>)" /V /FO LIST
Siehe Fehlerbehebung für mehr.
Wie starte/stoppe/starte ich den Gateway-Dienst neu?
Verwenden Sie die Gateway-Helfer:
openclaw gateway statusopenclaw gateway restartWenn Sie den Gateway manuell ausführen, kann openclaw gateway --force den Port zurückholen. Siehe Gateway.
Ich habe mein Terminal unter Windows geschlossen - wie starte ich OpenClaw neu?
Es gibt zwei Windows-Installationsmodi:
1) WSL2 (empfohlen): Der Gateway läuft innerhalb von Linux.
Öffnen Sie PowerShell, wechseln Sie in WSL und starten Sie dann neu:
wslopenclaw gateway statusopenclaw gateway restartWenn Sie den Dienst nie installiert haben, starten Sie ihn im Vordergrund:
openclaw gateway run2) Natives Windows (nicht empfohlen): Der Gateway läuft direkt unter Windows.
Öffnen Sie PowerShell und führen Sie aus:
openclaw gateway statusopenclaw gateway restartWenn Sie ihn manuell ausführen (kein Dienst), verwenden Sie:
openclaw gateway runDocs: Windows (WSL2), Gateway-Dienst-Runbook.
Der Gateway ist aktiv, aber Antworten kommen nie an. Was sollte ich prüfen?
Beginnen Sie mit einem schnellen Gesundheitscheck:
openclaw statusopenclaw models statusopenclaw channels statusopenclaw logs --followHäufige Ursachen:
- Modellauthentifizierung auf dem Gateway-Host nicht geladen (prüfen Sie
models status). - Channel-Pairing/Allowlist blockiert Antworten (prüfen Sie Channel-Konfiguration + Logs).
- WebChat/Dashboard ist ohne das richtige Token geöffnet.
Wenn Sie remote sind, bestätigen Sie, dass die Tunnel-/Tailscale-Verbindung aktiv ist und dass der Gateway-WebSocket erreichbar ist.
Doku: Channels, Fehlerbehebung, Remote-Zugriff.
"Vom Gateway getrennt: kein Grund" - was nun?
Das bedeutet normalerweise, dass die UI die WebSocket-Verbindung verloren hat. Prüfen Sie:
- Läuft das Gateway?
openclaw gateway status - Ist das Gateway fehlerfrei?
openclaw status - Hat die UI das richtige Token?
openclaw dashboard - Wenn remote, ist die Tunnel-/Tailscale-Verbindung aktiv?
Folgen Sie dann den Logs:
openclaw logs --followDoku: Dashboard, Remote-Zugriff, Fehlerbehebung.
Telegram setMyCommands schlägt fehl. Was sollte ich prüfen?
Beginnen Sie mit Logs und Channel-Status:
openclaw channels statusopenclaw channels logs --channel telegramOrdnen Sie dann den Fehler zu:
BOT_COMMANDS_TOO_MUCH: Das Telegram-Menü hat zu viele Einträge. OpenClaw kürzt bereits auf das Telegram-Limit und versucht es mit weniger Befehlen erneut, aber einige Menüeinträge müssen dennoch entfernt werden. Reduzieren Sie Plugin-/Skill-/benutzerdefinierte Befehle, oder deaktivieren Siechannels.telegram.commands.native, wenn Sie das Menü nicht benötigen.TypeError: fetch failed,Network request for 'setMyCommands' failed!oder ähnliche Netzwerkfehler: Wenn Sie auf einem VPS oder hinter einem Proxy sind, bestätigen Sie, dass ausgehendes HTTPS erlaubt ist und DNS fürapi.telegram.orgfunktioniert.
Wenn das Gateway remote ist, stellen Sie sicher, dass Sie die Logs auf dem Gateway-Host ansehen.
Doku: Telegram, Channel-Fehlerbehebung.
TUI zeigt keine Ausgabe. Was sollte ich prüfen?
Bestätigen Sie zuerst, dass das Gateway erreichbar ist und der Agent ausgeführt werden kann:
openclaw statusopenclaw models statusopenclaw logs --followVerwenden Sie in der TUI /status, um den aktuellen Zustand zu sehen. Wenn Sie Antworten in einem Chat-
Channel erwarten, stellen Sie sicher, dass die Zustellung aktiviert ist (/deliver on).
Doku: TUI, Slash-Befehle.
Wie stoppe ich das Gateway vollständig und starte es dann wieder?
Wenn Sie den Dienst installiert haben:
openclaw gateway stopopenclaw gateway startDies stoppt/startet den überwachten Dienst (launchd auf macOS, systemd auf Linux). Verwenden Sie dies, wenn das Gateway im Hintergrund als Daemon läuft.
Wenn Sie es im Vordergrund ausführen, stoppen Sie mit Strg-C und dann:
openclaw gateway runDoku: Gateway-Dienst-Runbook.
ELI5: openclaw gateway restart gegenüber openclaw gateway
openclaw gateway restart: startet den Hintergrunddienst neu (launchd/systemd).openclaw gateway: führt das Gateway im Vordergrund für diese Terminal-Sitzung aus.
Wenn Sie den Dienst installiert haben, verwenden Sie die Gateway-Befehle. Verwenden Sie openclaw gateway, wenn
Sie einen einmaligen Vordergrundlauf möchten.
Schnellster Weg zu mehr Details, wenn etwas fehlschlägt
Starten Sie das Gateway mit --verbose, um mehr Konsolendetails zu erhalten. Prüfen Sie dann die Logdatei auf Channel-Authentifizierung, Modell-Routing und RPC-Fehler.
Medien und Anhänge
Mein Skill hat ein Bild/PDF erzeugt, aber nichts wurde gesendet
Ausgehende Anhänge vom Agenten müssen eine MEDIA:<path-or-url>-Zeile enthalten (in einer eigenen Zeile). Siehe OpenClaw-Assistent einrichten und Agent send.
Senden per CLI:
openclaw message send --target +15555550123 --message "Here you go" --media /path/to/file.pngPrüfen Sie außerdem:
- Der Ziel-Channel unterstützt ausgehende Medien und wird nicht durch Allowlists blockiert.
- Die Datei liegt innerhalb der Größenlimits des Providers (Bilder werden auf maximal 2048 px verkleinert).
tools.fs.workspaceOnly=truebeschränkt Sendevorgänge mit lokalen Pfaden auf Workspace, temporären/Media-Store und durch die Sandbox validierte Dateien.tools.fs.workspaceOnly=falselässtMEDIA:host-lokale Dateien senden, die der Agent bereits lesen kann, aber nur für Medien sowie sichere Dokumenttypen (Bilder, Audio, Video, PDF und Office-Dokumente). Klartext und geheimnisähnliche Dateien werden weiterhin blockiert.
Siehe Bilder.
Sicherheit und Zugriffskontrolle
Ist es sicher, OpenClaw für eingehende DMs freizugeben?
Behandeln Sie eingehende DMs als nicht vertrauenswürdige Eingabe. Die Standardeinstellungen sind darauf ausgelegt, Risiko zu reduzieren:
- Standardverhalten auf DM-fähigen Channels ist Pairing:
- Unbekannte Absender erhalten einen Pairing-Code; der Bot verarbeitet ihre Nachricht nicht.
- Genehmigen mit:
openclaw pairing approve --channel <channel> [--account <id>] <code> - Ausstehende Anfragen sind auf 3 pro Channel begrenzt; prüfen Sie
openclaw pairing list --channel <channel> [--account <id>], wenn ein Code nicht angekommen ist.
- Das öffentliche Öffnen von DMs erfordert explizites Opt-in (
dmPolicy: "open"und Allowlist"*").
Führen Sie openclaw doctor aus, um riskante DM-Richtlinien sichtbar zu machen.
Ist Prompt Injection nur bei öffentlichen Bots ein Problem?
Nein. Bei Prompt Injection geht es um nicht vertrauenswürdige Inhalte, nicht nur darum, wer dem Bot eine DM senden kann. Wenn Ihr Assistent externe Inhalte liest (Websuche/-Abruf, Browserseiten, E-Mails, Dokumente, Anhänge, eingefügte Logs), können diese Inhalte Anweisungen enthalten, die versuchen, das Modell zu kapern. Das kann passieren, selbst wenn Sie der einzige Absender sind.
Das größte Risiko besteht, wenn Tools aktiviert sind: Das Modell kann dazu verleitet werden, Kontext zu exfiltrieren oder Tools in Ihrem Namen aufzurufen. Reduzieren Sie den möglichen Schaden durch:
- Verwendung eines schreibgeschützten oder Tool-deaktivierten „Reader“-Agenten zum Zusammenfassen nicht vertrauenswürdiger Inhalte
- Deaktivieren von
web_search/web_fetch/browserfür Tool-aktivierte Agenten - Behandlung von dekodiertem Datei-/Dokumenttext ebenfalls als nicht vertrauenswürdig: OpenResponses
input_fileund Medienanhang-Extraktion umschließen extrahierten Text beide mit expliziten Boundary-Markern für externe Inhalte, statt Rohdateitext zu übergeben - Sandboxing und strikte Tool-Allowlists
Details: Sicherheit.
Sollte mein Bot eine eigene E-Mail-Adresse, ein eigenes GitHub-Konto oder eine eigene Telefonnummer haben?
Ja, für die meisten Setups. Die Isolierung des Bots mit separaten Konten und Telefonnummern reduziert den möglichen Schaden, wenn etwas schiefgeht. Außerdem wird es dadurch einfacher, Anmeldedaten zu rotieren oder Zugriff zu widerrufen, ohne Ihre persönlichen Konten zu beeinträchtigen.
Fangen Sie klein an. Gewähren Sie nur Zugriff auf die Tools und Konten, die Sie tatsächlich benötigen, und erweitern Sie später bei Bedarf.
Doku: Sicherheit, Pairing.
Kann ich ihm Autonomie über meine Textnachrichten geben, und ist das sicher?
Wir empfehlen keine vollständige Autonomie über Ihre persönlichen Nachrichten. Das sicherste Muster ist:
- Belassen Sie DMs im Pairing-Modus oder in einer engen Allowlist.
- Verwenden Sie eine separate Nummer oder ein separates Konto, wenn es in Ihrem Namen Nachrichten senden soll.
- Lassen Sie es Entwürfe erstellen und genehmigen Sie vor dem Senden.
Wenn Sie experimentieren möchten, tun Sie das auf einem dedizierten Konto und halten Sie es isoliert. Siehe Sicherheit.
Kann ich günstigere Modelle für Aufgaben eines persönlichen Assistenten verwenden?
Ja, wenn der Agent nur chattet und die Eingabe vertrauenswürdig ist. Kleinere Stufen sind anfälliger für das Kapern durch Anweisungen, daher sollten Sie sie für Tool-aktivierte Agenten oder beim Lesen nicht vertrauenswürdiger Inhalte vermeiden. Wenn Sie ein kleineres Modell verwenden müssen, sperren Sie Tools ab und führen Sie es in einer Sandbox aus. Siehe Sicherheit.
Ich habe /start in Telegram ausgeführt, aber keinen Pairing-Code erhalten
Pairing-Codes werden nur gesendet, wenn ein unbekannter Absender dem Bot eine Nachricht sendet und
dmPolicy: "pairing" aktiviert ist. /start allein erzeugt keinen Code.
Prüfen Sie ausstehende Anfragen:
openclaw pairing list telegramWenn Sie sofortigen Zugriff möchten, setzen Sie Ihre Absender-ID auf die Allowlist oder setzen Sie dmPolicy: "open"
für dieses Konto.
WhatsApp: Wird es meinen Kontakten Nachrichten senden? Wie funktioniert Pairing?
Nein. Die Standard-DM-Richtlinie von WhatsApp ist Pairing. Unbekannte Absender erhalten nur einen Pairing-Code und ihre Nachricht wird nicht verarbeitet. OpenClaw antwortet nur auf Chats, die es empfängt, oder auf explizite Sendevorgänge, die Sie auslösen.
Pairing genehmigen mit:
openclaw pairing approve whatsapp <code>Ausstehende Anfragen auflisten:
openclaw pairing list whatsappTelefonnummernabfrage im Wizard: Sie wird verwendet, um Ihre Allowlist/Owner festzulegen, damit Ihre eigenen DMs erlaubt sind. Sie wird nicht für automatisches Senden verwendet. Wenn Sie Ihre persönliche WhatsApp-Nummer verwenden, verwenden Sie diese Nummer und aktivieren Sie channels.whatsapp.selfChatMode.
Chat-Befehle, Aufgaben abbrechen und „es hört nicht auf“
Wie verhindere ich, dass interne Systemnachrichten im Chat angezeigt werden?
Die meisten internen oder Tool-Nachrichten erscheinen nur, wenn verbose, trace oder reasoning für diese Sitzung aktiviert ist.
Beheben Sie es in dem Chat, in dem Sie es sehen:
/verbose off/trace off/reasoning offWenn es weiterhin zu viel Ausgabe gibt, prüfen Sie die Sitzungseinstellungen in der Control UI und setzen Sie verbose
auf inherit. Bestätigen Sie außerdem, dass Sie kein Bot-Profil verwenden, bei dem verboseDefault in der Konfiguration
auf on gesetzt ist.
Doku: Denken und verbose, Sicherheit.
Wie stoppe/breche ich eine laufende Aufgabe ab?
Senden Sie eines davon als eigenständige Nachricht (kein Slash):
stopstop actionstop current actionstop runstop current runstop agentstop the agentstop openclawopenclaw stopstop don't do anythingstop do not do anythingstop doing anythingplease stopstop pleaseabortescwaitexitinterruptDies sind Abbruchauslöser (keine Slash-Befehle).
Für Hintergrundprozesse (aus dem exec-Tool) können Sie den Agenten bitten, Folgendes auszuführen:
process action:kill sessionId:XXXÜberblick über Slash-Befehle: siehe Slash-Befehle.
Die meisten Befehle müssen als eigenständige Nachricht gesendet werden, die mit / beginnt, aber einige Kurzbefehle (wie /status) funktionieren für Absender auf der Allowlist auch inline.
Wie sende ich eine Discord-Nachricht aus Telegram? („Cross-context messaging denied“)
OpenClaw blockiert providerübergreifendes Messaging standardmäßig. Wenn ein Tool-Aufruf an Telegram gebunden ist, sendet er nicht an Discord, sofern Sie es nicht explizit erlauben.
Aktivieren Sie providerübergreifendes Messaging für den Agenten:
{ tools: { message: { crossContext: { allowAcrossProviders: true, marker: { enabled: true, prefix: "[from {channel}] " }, }, }, },}Starten Sie das Gateway nach dem Bearbeiten der Konfiguration neu.
Warum fühlt es sich so an, als würde der Bot schnelle Nachrichtenfolgen „ignorieren“?
Der Queue-Modus steuert, wie neue Nachrichten mit einem laufenden Run interagieren. Verwenden Sie /queue, um Modi zu ändern:
steer- alle ausstehenden Steuerhinweise für die nächste Modellgrenze im aktuellen Run in die Warteschlange stellenqueue- Legacy-Steuerung, jeweils eine nach der anderenfollowup- Nachrichten nacheinander ausführencollect- Nachrichten bündeln und einmal antwortensteer-backlog- jetzt steuern, dann Rückstand verarbeiteninterrupt- aktuellen Run abbrechen und frisch starten
Der Standardmodus ist steer. Sie können Optionen wie debounce:0.5s cap:25 drop:summarize für Folgemodi hinzufügen. Siehe Befehlswarteschlange und Steuerungswarteschlange.
Verschiedenes
Was ist das Standardmodell für Anthropic mit einem API-Schlüssel?
In OpenClaw sind Zugangsdaten und Modellauswahl getrennt. Das Setzen von ANTHROPIC_API_KEY (oder das Speichern eines Anthropic-API-Schlüssels in Auth-Profilen) aktiviert die Authentifizierung, aber das tatsächliche Standardmodell ist das, was Sie in agents.defaults.model.primary konfigurieren (zum Beispiel anthropic/claude-sonnet-4-6 oder anthropic/claude-opus-4-6). Wenn Sie No credentials found for profile "anthropic:default" sehen, bedeutet das, dass der Gateway die Anthropic-Zugangsdaten nicht in der erwarteten auth-profiles.json für den Agent finden konnte, der ausgeführt wird.
Kommen Sie immer noch nicht weiter? Fragen Sie in Discord oder eröffnen Sie eine GitHub-Diskussion.
Verwandte Themen
- FAQ zum ersten Start — Installation, Onboarding, Authentifizierung, Abonnements, frühe Fehler
- Modelle-FAQ — Modellauswahl, Failover, Auth-Profile
- Fehlerbehebung — symptombasierte Triage