DockerDocker
Docker est optionnel. Utilisez-le uniquement si vous souhaitez une passerelle conteneurisée ou pour valider le flux Docker.
Docker est-il fait pour moi ?
Section intitulée « Docker est-il fait pour moi ? »- Oui : vous souhaitez un environnement de passerelle isolé et éphémère, ou exécuter OpenClaw sur un hôte sans installation locale.
- Non : vous exécutez sur votre propre machine et vous voulez simplement la boucle de développement la plus rapide. Utilisez plutôt le flux d’installation normal.
- Sandboxing note : le backend de sandbox par défaut utilise Docker lorsque le sandboxing est activé, mais le sandboxing est désactivé par défaut et n’exige pas que l’intégralité de la passerelle s’exécute dans Docker. Les backends de sandbox SSH et OpenShell sont également disponibles. Voir Sandboxing.
Prérequis
Section intitulée « Prérequis »- Docker Desktop (ou Docker Engine) + Docker Compose v2
- Au moins 2 Go de RAM pour la build de l’image (
pnpm installpeut être tué par OOM sur des hôtes de 1 Go avec le code de sortie 137) - Assez d’espace disque pour les images et les journaux
- Si vous exécutez sur un VPS/hôte public, consultez
Durcissement de la sécurité pour l’exposition réseau,
en particulier la stratégie de pare-feu
DOCKER-USERde Docker.
Passerelle conteneurisée
Section intitulée « Passerelle conteneurisée »Build the image
À partir de la racine du dépôt, exécutez le script de configuration :
Fenêtre de terminal ./scripts/docker/setup.shCela construit localement l’image de la passerelle. Pour utiliser à la place une image préconstruite :
Fenêtre de terminal export OPENCLAW_IMAGE="ghcr.io/openclaw/openclaw:latest"./scripts/docker/setup.shLes images préconstruites sont publiées sur le GitHub Container Registry. Tags courants :
main,latest, `(ex.2026.2.26`).Complete onboarding
Le script de configuration exécute l’onboarding automatiquement. Il va :
- demander les clés API du provider
- générer un jeton de passerelle et l’écrire dans
.env - créer le répertoire de la clé secrète de l’auth-profile
- démarrer la passerelle via Docker Compose
Pendant la configuration, l’onboarding pré-démarrage et les écritures de configuration s’exécutent via
openclaw-gatewaydirectement.openclaw-cliest destiné aux commandes que vous exécutez une fois que le conteneur de la passerelle existe déjà.Open the Control UI
Ouvrez
http://127.0.0.1:18789/dans votre navigateur et collez le secret partagé configuré dans les paramètres. Le script de configuration écrit un jeton dans.envpar défaut ; si vous basculez la configuration du conteneur vers une authentification par mot de passe, utilisez ce mot de passe à la place.Besoin de l’URL à nouveau ?
Fenêtre de terminal docker compose run --rm openclaw-cli dashboard --no-openConfigurer les canaux (facultatif)
Utilisez le conteneur CLI pour ajouter des canaux de messagerie :
Fenêtre de terminal # WhatsApp (QR)docker compose run --rm openclaw-cli channels login# Telegramdocker compose run --rm openclaw-cli channels add --channel telegram --token "”
# Discorddocker compose run --rm openclaw-cli channels add --channel discord --token "” ```WhatsApp
Docs : [WhatsApp](/en/channels/whatsappTelegram), [Telegram](/en/channels/telegramDiscord), [Discord](/en/channels/discord)
Flux manuel
Section intitulée « Flux manuel »Si vous préférez exécuter chaque étape vous-même au lieu d’utiliser le script de configuration :
docker build -t openclaw:local -f Dockerfile .docker compose run --rm --no-deps --entrypoint node openclaw-gateway \ dist/index.js onboard --mode local --no-install-daemondocker compose run --rm --no-deps --entrypoint node openclaw-gateway \ dist/index.js config set --batch-json '[{"path":"gateway.mode","value":"local"},{"path":"gateway.bind","value":"lan"},{"path":"gateway.controlUi.allowedOrigins","value":["http://localhost:18789","http://127.0.0.1:18789"]}]'docker compose up -d openclaw-gatewayVariables d’environnement
Section intitulée « Variables d’environnement »Le script de configuration accepte ces variables d’environnement optionnelles :
| Variable | Objectif |
|---|---|
OPENCLAW_IMAGE | Utiliser une image distante au lieu de construire localement |
OPENCLAW_IMAGE_APT_PACKAGES | Installer des packages apt supplémentaires lors de la construction (séparés par des espaces) |
OPENCLAW_IMAGE_PIP_PACKAGES | Installer des packages Python supplémentaires lors de la build (séparés par des espaces) |
OPENCLAW_EXTENSIONS | Pré-installer les dépendances des plugins au moment de la build (noms séparés par des espaces) |
OPENCLAW_EXTRA_MOUNTS | Montages de liaison d’hôte supplémentaires (séparés par des virgules source:target[:opts]) |
OPENCLAW_HOME_VOLUME | Persister /home/nodeDocker dans un volume Docker nommé |
OPENCLAW_SANDBOX | Opter pour le bootstrap du bac à sable (1, true, yes, on) |
OPENCLAW_SKIP_ONBOARDING | Ignorer l’étape d’onboarding interactif (1, true, yes, on) |
OPENCLAW_DOCKER_SOCKET | Remplacer le chemin du socket Docker |
OPENCLAW_DISABLE_BONJOUR | Désactiver la publicité Bonjour/mDNS (par défaut Bonjour1Docker pour Docker) |
OPENCLAW_DISABLE_BUNDLED_SOURCE_OVERLAYS | Désactiver les superpositions de montage bind pour les sources de plugins intégrés |
OTEL_EXPORTER_OTLP_ENDPOINT | Point de terminaison de collecteur OTLP/HTTP partagé pour l’exportation OpenTelemetry |
OTEL_EXPORTER_OTLP_*_ENDPOINT | Points de terminaison OTLP spécifiques aux Signal pour les traces, les métriques ou les journaux |
OTEL_EXPORTER_OTLP_PROTOCOL | Remplacement du protocole OTLP. Seul http/protobuf est pris en charge à l’heure actuelle |
OTEL_SERVICE_NAME | Nom de service utilisé pour les ressources OpenTelemetry |
OTEL_SEMCONV_STABILITY_OPT_IN | Activer les derniers attributs sémantiques expérimentaux GenAI |
OPENCLAW_OTEL_PRELOADED | Ignorer le démarrage d’un deuxième SDK OpenTelemetry lorsqu’un est déjà préchargé |
L’image officielle Docker n’inclut pas Homebrew. Lors de l’onboarding, OpenClaw
masque les programmes d’installation de dépendances de compétences exclusives à brew lorsqu’il s’exécute dans un conteneur
Linux sans brew; ces dépendances doivent être fournies par une image personnalisée
ou installées manuellement. Pour les dépendances disponibles via les packages Debian, utilisez
OPENCLAW_IMAGE_APT_PACKAGES lors de la construction de l’image. L’ancien nom
OPENCLAW_DOCKER_APT_PACKAGES est toujours accepté.
Pour les dépendances Python, utilisez OPENCLAW_IMAGE_PIP_PACKAGES. Cela exécute
python3 -m pip install --break-system-packages lors de la construction de l’image, épinglez donc
les versions des packages et n’utilisez que des index de packages auxquels vous faites confiance.
Les mainteneurs peuvent tester la source des plugins intégrés par rapport à une image empaquetée en montant
un répertoire source de plugin sur son chemin source empaqueté, par exemple
OPENCLAW_EXTRA_MOUNTS=/path/to/fork/extensions/synology-chat:/app/extensions/synology-chat:ro.
Ce répertoire source monté remplace le bundle /app/dist/extensions/synology-chat compilé correspondant
pour le même identifiant de plugin.
Observabilité
Section intitulée « Observabilité »L’exportation OpenTelemetry est sortante du conteneur Gateway vers votre collecteur OTLP. Elle ne nécessite pas de port Docker publié. Si vous construisez l’image localement et souhaitez que l’exportateur OpenTelemetry intégré soit disponible dans l’image, incluez ses dépendances d’exécution :
export OPENCLAW_EXTENSIONS="diagnostics-otel"export OTEL_EXPORTER_OTLP_ENDPOINT="http://otel-collector:4318"export OTEL_SERVICE_NAME="openclaw-gateway"./scripts/docker/setup.shInstallez le plugin officiel @openclaw/diagnostics-otel depuis ClawHub dans
les installations Docker empaquetées avant d’activer l’exportation. Les images personnalisées construites à partir des sources peuvent
toujours inclure la source du plugin local avec
OPENCLAW_EXTENSIONS=diagnostics-otel. Pour activer l’exportation, autorisez et activez le
plugin diagnostics-otel dans la configuration, puis définissez
diagnostics.otel.enabled=true ou utilisez l’exemple de configuration dans exportation
OpenTelemetry. Les en-têtes d’authentification du collecteur sont configurés via
diagnostics.otel.headers, et non via les variables d’environnement Docker.
Les métriques Prometheus utilisent le port du Gateway déjà publié. Installez
clawhub:@openclaw/diagnostics-prometheus, activez le
plugin diagnostics-prometheus, puis scrapez :
http://<gateway-host>:18789/api/diagnostics/prometheusLa route est protégée par l’authentification du Gateway. N’exposez pas un port
public /metrics séparé ni un chemin de proxy inverse non authentifié. Voir
Métriques Prometheus.
Contrôles de santé
Section intitulée « Contrôles de santé »Points de terminaison de sonde de conteneur (aucune authentification requise) :
curl -fsS http://127.0.0.1:18789/healthz # livenesscurl -fsS http://127.0.0.1:18789/readyz # readinessL’image Docker inclut un HEALTHCHECK intégré qui effectue un ping sur /healthz.
Si les vérifications échouent continuellement, Docker marque le conteneur comme unhealthy et
les systèmes d’orchestration peuvent le redémarrer ou le remplacer.
Instantané de santé approfondie authentifié :
docker compose exec openclaw-gateway node dist/index.js health --token "$OPENCLAW_GATEWAY_TOKEN"LAN vs boucle locale
Section intitulée « LAN vs boucle locale »scripts/docker/setup.sh utilise par défaut OPENCLAW_GATEWAY_BIND=lan pour que l’accès hôte à
http://127.0.0.1:18789 fonctionne avec la publication de ports Docker.
lan(par défaut) : le navigateur hôte et la CLI hôte peuvent atteindre le port de passerelle publié.loopback: seuls les processus à l’intérieur de l’espace de noms réseau du conteneur peuvent atteindre directement la passerelle.
Fournisseurs locaux de l’hôte
Section intitulée « Fournisseurs locaux de l’hôte »Lorsque OpenClaw s’exécute dans Docker, 127.0.0.1 à l’intérieur du conteneur est le conteneur
lui-même, et non votre machine hôte. Utilisez host.docker.internal pour les fournisseurs d’IA qui
s’exécutent sur l’hôte :
| Fournisseur | URL par défaut de l’hôte | URL de configuration Docker |
|---|---|---|
| LM Studio | http://127.0.0.1:1234 | http://host.docker.internal:1234 |
| Ollama | http://127.0.0.1:11434 | http://host.docker.internal:11434 |
La configuration Docker fournie utilise ces URLs d’hôte comme valeurs par défaut d’onboarding pour LM Studio et Ollama,
et docker-compose.yml mappe host.docker.internal vers
la passerelle hôte de Docker pour le moteur Linux Docker. Docker Desktop fournit déjà
le même nom d’hôte sur macOS et Windows.
Les services de l’hôte doivent également écouter sur une adresse accessible depuis Docker :
lms server start --port 1234 --bind 0.0.0.0OLLAMA_HOST=0.0.0.0:11434 ollama serveSi vous utilisez votre propre fichier Compose ou la commande docker run, ajoutez vous-même le même mappage d’hôte,
par exemple --add-host=host.docker.internal:host-gateway.
Bonjour / mDNS
Section intitulée « Bonjour / mDNS »Le réseau pont Docker ne transmet généralement pas de manière fiable le multidiffusion
Bonjour/mDNS (224.0.0.251:5353). La configuration Compose fournie définit donc par défaut
OPENCLAW_DISABLE_BONJOUR=1 afin que le Gateway ne boucle pas sur des crashs ou ne redémarre pas
répétitivement la publicité lorsque le pont abandonne le trafic multidiffusion.
Utilisez l’URL publiée du Gateway, Tailscale ou DNS-SD étendu pour les hôtes Docker.
Définissez OPENCLAW_DISABLE_BONJOUR=0 uniquement lors de l’exécution avec le réseau hôte, macvlan,
ou un autre réseau où le multidiffusion mDNS est connu pour fonctionner.
Pour les pièges et le troubleshooting, consultez découverte Bonjour.
Stockage et persistance
Section intitulée « Stockage et persistance »Le Docker Compose lie (bind-mounts) OPENCLAW_CONFIG_DIR à /home/node/.openclaw,
OPENCLAW_WORKSPACE_DIR à /home/node/.openclaw/workspace, et
OPENCLAW_AUTH_PROFILE_SECRET_DIR à /home/node/.config/openclaw, de sorte que ces
chemins survivent au remplacement du conteneur. Lorsqu’une variable n’est pas définie, le
docker-compose.yml groupé revient sous ${HOME}, ou /tmp lorsque HOME lui-même est
également manquant. Cela empêche docker compose up d’émettre une spécification de volume à source vide
sur des environnements nus.
Ce répertoire de configuration monté est là où OpenClaw conserve :
openclaw.jsonpour la configuration du comportementagents/<agentId>/agent/auth-profiles.jsonOAuth pour l’authentification par clé OAuth/API du provider stockée.envpour les secrets d’exécution sauvegardés par l’environnement tels queOPENCLAW_GATEWAY_TOKEN
Le répertoire des clés secrètes du profil d’authentification stocke la clé de chiffrement locale utilisée pour
le matériel de jeton de profil d’authentification soutenu par OAuth. Conservez-le avec l’état de votre hôte Docker,
mais séparément de OPENCLAW_CONFIG_DIR.
Les plugins téléchargeables installés stockent leur état de package sous le répertoire personnel (home) monté de OpenClaw, de sorte que les enregistrements d’installation des plugins et les racines des packages survivent au remplacement du conteneur. Le démarrage du Gateway ne génère pas les arbres de dépendance des plugins groupés.
Pour plus de détails sur la persistance des déploiements sur machine virtuelle, consultez Runtime VM Docker - Ce qui persiste où.
Points chauds de croissance du disque : surveillez media/, les fichiers JSONL de session,
cron/runs/*.jsonl, les racines des packages de plugins installés, et les journaux de fichiers rotatifs
sous /tmp/openclaw/.
Assistants shell (optionnels)
Section intitulée « Assistants shell (optionnels) »Pour une gestion quotidienne plus facile de Docker, installez ClawDock :
mkdir -p ~/.clawdock && curl -sL https://raw.githubusercontent.com/openclaw/openclaw/main/scripts/clawdock/clawdock-helpers.sh -o ~/.clawdock/clawdock-helpers.shecho 'source ~/.clawdock/clawdock-helpers.sh' >> ~/.zshrc && source ~/.zshrcSi vous avez installé ClawDock à partir de l’ancien chemin brut scripts/shell-helpers/clawdock-helpers.sh, relancez la commande d’installation ci-dessus afin que votre fichier assistant local suive le nouvel emplacement.
Utilisez ensuite clawdock-start, clawdock-stop, clawdock-dashboard, etc. Exécutez
clawdock-help pour toutes les commandes.
Voir ClawDock pour le guide complet de l’assistant.
Activer le bac à sable de l'agent pour la passerelle Docker
export OPENCLAW_SANDBOX=1./scripts/docker/setup.shChemin de socket personnalisé (ex. Docker rootless) :
export OPENCLAW_SANDBOX=1export OPENCLAW_DOCKER_SOCKET=/run/user/1000/docker.sock./scripts/docker/setup.shLe script monte docker.sock uniquement après que les prérequis du bac à sable soient remplis. Si
la configuration du bac à sable ne peut pas être terminée, le script réinitialise agents.defaults.sandbox.mode
à off. Les tours de mode code de Codex sont toujours contraints au workspace-write Codex
pendant que le bac à sable OpenClaw est actif ; ne montez pas le
socket Docker de l’hôte dans les conteneurs du bac à sable de l’agent.
Automatisation / CI (non-interactif)
Désactivez l’allocation pseudo-TTY de Compose avec -T :
docker compose run -T --rm openclaw-cli gateway probedocker compose run -T --rm openclaw-cli devices list --jsonNote de sécurité réseau partagé
openclaw-cli utilise network_mode: "service:openclaw-gateway" pour que les commandes CLI puissent atteindre la passerelle via 127.0.0.1. Considérez cela comme une limite de confiance partagée. La configuration compose abandonne NET_RAW/NET_ADMIN et active no-new-privileges à la fois sur openclaw-gateway et openclaw-cli.
Échecs DNS Docker Desktop dans openclaw-cli
Certaines configurations Docker Desktop échouent aux recherches DNS à partir du sidecar
openclaw-cli sur réseau partagé après que NET_RAW a été abandonné, ce qui se manifeste par
EAI_AGAIN lors des commandes soutenues par npm telles que openclaw plugins install.
Conservez le fichier compose renforcé par défaut pour le fonctionnement normal de la passerelle. La
substitution locale ci-dessous assouplit la posture de sécurité du conteneur CLI en
restaurant les capacités par défaut de Docker, utilisez-la donc uniquement pour la commande
CLI ponctuelle qui nécessite un accès au registre de paquets, et non comme votre invocation
Compose par défaut :
printf '%s\n' \ 'services:' \ ' openclaw-cli:' \ ' cap_drop: !reset []' \ > docker-compose.cli-no-dropped-caps.local.yml
docker compose -f docker-compose.yml -f docker-compose.cli-no-dropped-caps.local.yml run --rm openclaw-cli plugins installSi vous avez déjà créé un conteneur `openclaw-cli` à longue durée de vie, recréez-leavec la même substitution. `docker compose exec` et `docker exec` ne peuvent pasmodifier les capacités Linux sur un conteneur déjà créé.Permissions and EACCES
L’image s’exécute en tant que node (uid 1000). Si vous rencontrez des erreurs de permissions sur
/home/node/.openclaw, assurez-vous que vos montages de liaison hôtes appartiennent à l’uid 1000 :
sudo chown -R 1000:1000 /path/to/openclaw-config /path/to/openclaw-workspaceLe même conflit peut apparaître sous forme d’avertissement de plugin tel que
blocked plugin candidate: suspicious ownership (... uid=1000, expected uid=0 or root)
suivi de plugin present but blocked. Cela signifie que l’uid du processus et le
propriétaire du répertoire du plugin monté ne correspondent pas. Privilégiez l’exécution du conteneur avec l’uid 1000 par défaut
et la correction de la propriété du montage de liaison. N’exécutez chown
/path/to/openclaw-config/npm vers root:rootOpenClaw que si vous exécutez intentionnellement
OpenClaw en tant que root à long terme.
Faster rebuilds
Ordonnez votre Dockerfile afin que les couches de dépendances soient mises en cache. Cela évite de réexécuter
pnpm install sauf si les fichiers de verrouillage changent :
FROM node:24-bookwormRUN curl -fsSL https://bun.sh/install | bashENV PATH="/root/.bun/bin:${PATH}"RUN corepack enableWORKDIR /appCOPY package.json pnpm-lock.yaml pnpm-workspace.yaml .npmrc ./COPY ui/package.json ./ui/package.jsonCOPY scripts ./scriptsRUN pnpm install --frozen-lockfileCOPY . .RUN pnpm buildRUN pnpm ui:installRUN pnpm ui:buildENV NODE_ENV=productionCMD ["node","dist/index.js"]Power-user container options
L’image par défaut privilégie la sécurité et s’exécute en tant que non-root node. Pour un conteneur plus complet :
- Persister
/home/node:export OPENCLAW_HOME_VOLUME="openclaw_home" - Intégrer les dépendances système :
export OPENCLAW_IMAGE_APT_PACKAGES="git curl jq" - Intégrer les dépendances Python :
export OPENCLAW_IMAGE_PIP_PACKAGES="requests==2.32.5 humanize==4.14.0" - Intégrer Playwright Chromium :
export OPENCLAW_INSTALL_BROWSER=1 - Ou installer les navigateurs Playwright dans un volume persistant :
Fenêtre de terminal docker compose run --rm openclaw-cli \node /app/node_modules/playwright-core/cli.js install chromium - Persister les téléchargements du navigateur : utilisez
OPENCLAW_HOME_VOLUMEouOPENCLAW_EXTRA_MOUNTSOpenClawDockerLinux. OpenClaw détecte automatiquement le Chromium géré par Playwright de l’image Docker sur Linux.
OpenAIOAuthDockerOpenAI Codex OAuth (headless Docker)
Si vous choisissez OpenAI Codex OAuth dans l’assistant, il ouvre une URL de navigateur. Dans Docker ou les configurations sans interface, copiez l’URL de redirection complète sur laquelle vous atterrissez et collez-la dans l’assistant pour terminer l’authentification.
Métadonnées de l'image de base
L’image d’exécution Docker principale utilise node:24-bookworm-slim et inclut tini comme processus d’initialisation du point d’entrée (PID 1) pour garantir que les processus zombies sont récoltés et que les signaux sont gérés correctement dans les conteneurs longue durée. Elle publie des annotations d’image de base OCI, notamment org.opencontainers.image.base.name,
org.opencontainers.image.sourceDocker, et d’autres. Le condensé de base Node est
actualisé via les PR Dependabot de l’image de base Docker ; les versions de release n’exécutent pas
une couche de mise à niveau de distribution. Voir
annotations d’image OCI.
Exécution sur un VPS ?
Section intitulée « Exécution sur un VPS ? »Voir Hetzner (VPS Docker) et Runtime VM Docker pour les étapes de déploiement sur VM partagée incluant la préparation des binaires, la persistance et les mises à jour.
Bac à sable de l’agent
Section intitulée « Bac à sable de l’agent »Lorsque agents.defaults.sandboxDockerDocker est activé avec le backend Docker, la passerelle
exécute les outils de l’agent (shell, lecture/écriture de fichiers, etc.) à l’intérieur de conteneurs Docker
isolés tandis que la passerelle elle-même reste sur l’hôte. Cela vous offre une barrière stricte
autour des sessions d’agent non fiables ou multi-locataires sans conteneuriser l’ensemble de la
passerelle.
La portée du bac à sable peut être par agent (par défaut), par session, ou partagée. Chaque portée
obtient son propre espace de travail monté sur /workspace. Vous pouvez également configurer
les stratégies d’outils d’autorisation/refus, l’isolation du réseau, les limites de ressources et les conteneurs
de navigateur.
Pour la configuration complète, les images, les notes de sécurité et les profils multi-agents, voir :
- Sandboxing — référence complète du sandbox
- OpenShell — accès shell interactif aux conteneurs sandbox
- Multi-Agent Sandbox and Tools — substitutions par agent
Activation rapide
Section intitulée « Activation rapide »{ agents: { defaults: { sandbox: { mode: "non-main", // off | non-main | all scope: "agent", // session | agent | shared }, }, },}Construire l’image sandbox par défaut (à partir d’une copie des sources) :
scripts/sandbox-setup.shPour les installations npm sans copie des sources, consultez Sandboxing § Images and setup pour les commandes docker build en ligne.
Dépannage
Section intitulée « Dépannage »Image manquante ou conteneur sandbox ne démarre pas
Construisez l’image sandbox avec
scripts/sandbox-setup.sh
(copie des sources) ou la commande docker build en ligne de Sandboxing § Images and setup (installation npm),
ou définissez agents.defaults.sandbox.docker.image sur votre image personnalisée.
Les conteneurs sont créés automatiquement par session à la demande.
Erreurs de permission dans le sandbox
Définissez docker.user sur un UID:GID correspondant à la propriété de votre espace de travail monté, ou utilisez chown sur le dossier de l’espace de travail.
Outils personnalisés introuvables dans le sandbox
OpenClaw exécute les commandes avec sh -lc (login shell), ce qui source /etc/profile et peut réinitialiser PATH. Définissez docker.env.PATH pour préparer vos chemins d’outils personnalisés, ou ajoutez un script sous /etc/profile.d/ dans votre Dockerfile.
OOM-killed lors de la construction de l'image (exit 137)
La VM a besoin d’au moins 2 Go de RAM. Utilisez une classe de machine plus grande et réessayez.
Unauthorized or pairing required in Control UI
Récupérez un lien frais vers le tableau de bord et approuvez l’appareil du navigateur :
docker compose run --rm openclaw-cli dashboard --no-opendocker compose run --rm openclaw-cli devices listdocker compose run --rm openclaw-cli devices approvePlus de détails : [Tableau de bord](/fr/web/dashboard), [Appareils](/fr/cli/devices).GatewayDockerCLILa cible du Gateway affiche ws://172.x.x.x ou des erreurs d'appairage depuis le CLI Docker
Réinitialisez le mode du Gateway et la liaison :
docker compose run --rm openclaw-cli config set --batch-json '[{"path":"gateway.mode","value":"local"},{"path":"gateway.bind","value":"lan"}]'docker compose run --rm openclaw-cli devices list --url ws://127.0.0.1:18789Connexes
Section intitulée « Connexes »- Vue d’ensemble de l’installation — toutes les méthodes d’installation
- Podman — alternative Podman à Docker
- ClawDock — configuration communautaire Docker Compose
- Mises à jour — garder OpenClaw à jour
- Configuration — configuration du Gateway après l’installation