Podman
Ejecuta el OpenClaw Gateway en un contenedor rootless de Podman, gestionado por tu usuario no root actual.
El modelo previsto es:
- Podman ejecuta el contenedor del gateway.
- Tu
openclawCLI del host es el plano de control. - El estado persistente reside en el host bajo
~/.openclawde forma predeterminada. - La gestión día a día utiliza
openclaw --container <name> ...en lugar desudo -u openclaw,podman execo un usuario de servicio separado.
Requisitos previos
Sección titulada «Requisitos previos»- Podman en modo rootless
- OpenClaw CLI instalado en el host
- Opcional:
systemd --usersi deseas el inicio automático gestionado por Quadlet - Opcional:
sudosolo si deseasloginctl enable-linger "$(whoami)"para la persistencia al arranque en un host headless
Inicio rápido
Sección titulada «Inicio rápido»Configuración única
Desde la raíz del repositorio, ejecuta
./scripts/podman/setup.sh.Iniciar el contenedor del Gateway
Inicia el contenedor con
./scripts/run-openclaw-podman.sh launch.Ejecutar el onboarding dentro del contenedor
Ejecuta
./scripts/run-openclaw-podman.sh launch setup, luego abrehttp://127.0.0.1:18789/.Gestionar el contenedor en ejecución desde el CLI del host
Establece
OPENCLAW_CONTAINER=openclaw, luego usa los comandos normales deopenclawdesde el host.
Detalles de la configuración:
./scripts/podman/setup.shconstruyeopenclaw:localen tu almacén rootless de Podman de forma predeterminada, o usaOPENCLAW_IMAGE/OPENCLAW_PODMAN_IMAGEsi estableces uno.- Crea
~/.openclaw/openclaw.jsoncongateway.mode: "local"si falta. - Crea
~/.openclaw/.envconOPENCLAW_GATEWAY_TOKENsi falta. - Para los lanzamientos manuales, el asistente lee solo una pequeña lista de permitidos (allowlist) de claves relacionadas con Podman desde
~/.openclaw/.envy pasa variables de entorno de tiempo de ejecución explícitas al contenedor; no entrega el archivo de entorno completo a Podman.
Configuración gestionada por Quadlet:
./scripts/podman/setup.sh --quadletQuadlet es una opción solo para Linux porque depende de los servicios de usuario de systemd.
También puedes establecer OPENCLAW_PODMAN_QUADLET=1.
Variables de entorno de compilación/configuración opcionales:
OPENCLAW_IMAGEoOPENCLAW_PODMAN_IMAGE— usa una imagen existente/descargada en lugar de compilaropenclaw:localOPENCLAW_IMAGE_APT_PACKAGES— instala paquetes apt adicionales durante la construcción de la imagen (también aceptaOPENCLAW_DOCKER_APT_PACKAGESheredado)OPENCLAW_IMAGE_PIP_PACKAGES— instala paquetes adicionales de Python durante la compilación de la imagen; fija las versiones y usa solo índices de paquetes que confíesOPENCLAW_EXTENSIONS— preinstala las dependencias de los complementos en tiempo de compilaciónOPENCLAW_INSTALL_BROWSER— preinstala Chromium y Xvfb para la automatización del navegador (establezca en1para habilitar)
Inicio del contenedor:
./scripts/run-openclaw-podman.sh launchEl script inicia el contenedor como tu uid/gid actual con --userns=keep-id y monta el estado de OpenClaw en el contenedor mediante bind-mount.
Incorporación:
./scripts/run-openclaw-podman.sh launch setupLuego abre http://127.0.0.1:18789/ y usa el token de ~/.openclaw/.env.
Predeterminado de la CLI del host:
export OPENCLAW_CONTAINER=openclawLuego, comandos como estos se ejecutarán automáticamente dentro de ese contenedor:
openclaw dashboard --no-openopenclaw gateway status --deep # includes extra service scanopenclaw doctoropenclaw channels loginEn macOS, Podman machine puede hacer que el navegador aparezca como no local para la puerta de enlace. Si la interfaz de usuario de Control reporta errores de autenticación de dispositivo después del lanzamiento, usa la guía de Tailscale en Podman and Tailscale.
Podman y Tailscale
Sección titulada «Podman y Tailscale»Para acceso HTTPS o acceso remoto desde el navegador, sigue la documentación principal de Tailscale.
Nota específica de Podman:
- Mantén el host de publicación de Podman en
127.0.0.1. - Prefiere
tailscale serveadministrado por el host sobreopenclaw gateway --tailscale serve. - En macOS, si el contexto de autenticación de dispositivo del navegador local no es fiable, usa el acceso de Tailscale en lugar de soluciones temporales de túnel local.
Ver:
Systemd (Quadlet, opcional)
Sección titulada «Systemd (Quadlet, opcional)»Si ejecutaste ./scripts/podman/setup.sh --quadlet, la instalación crea un archivo Quadlet en:
~/.config/containers/systemd/openclaw.containerComandos útiles:
- Inicio:
systemctl --user start openclaw.service - Detener:
systemctl --user stop openclaw.service - Estado:
systemctl --user status openclaw.service - Registros:
journalctl --user -u openclaw.service -f
Después de editar el archivo Quadlet:
systemctl --user daemon-reloadsystemctl --user restart openclaw.servicePara la persistencia al arranque en hosts SSH/headless, habilita la persistencia (lingering) para tu usuario actual:
sudo loginctl enable-linger "$(whoami)"Configuración, entorno y almacenamiento
Sección titulada «Configuración, entorno y almacenamiento»- Dir. de configuración:
~/.openclaw - Dir. de espacio de trabajo:
~/.openclaw/workspace - Archivo de token:
~/.openclaw/.env - Asistente de lanzamiento:
./scripts/run-openclaw-podman.sh
El script de lanzamiento y Quadlet montan el estado del host en el contenedor mediante bind-mount:
OPENCLAW_CONFIG_DIR->/home/node/.openclawOPENCLAW_WORKSPACE_DIR->/home/node/.openclaw/workspace
De forma predeterminada, estos son directorios del host, no un estado anónimo del contenedor, por lo que
openclaw.json, auth-profiles.json por agente, estado del canal/proveedor,
sesiones y el espacio de trabajo sobreviven al reemplazo del contenedor.
La configuración de Podman también inicializa gateway.controlUi.allowedOrigins para 127.0.0.1 y localhost en el puerto de la puerta de enlace publicado para que el panel local funcione con el enlace de no bucle local del contenedor.
Variables de entorno útiles para el iniciador manual:
OPENCLAW_PODMAN_CONTAINER— nombre del contenedor (openclawde forma predeterminada)OPENCLAW_PODMAN_IMAGE/OPENCLAW_IMAGE— imagen a ejecutarOPENCLAW_PODMAN_GATEWAY_HOST_PORT— puerto del host asignado al contenedor18789OPENCLAW_PODMAN_BRIDGE_HOST_PORT— puerto del host asignado al contenedor18790OPENCLAW_PODMAN_PUBLISH_HOST— interfaz del host para los puertos publicados; el valor predeterminado es127.0.0.1OPENCLAW_GATEWAY_BIND— modo de enlace de la puerta de enlace dentro del contenedor; el valor predeterminado eslanOPENCLAW_PODMAN_USERNS—keep-id(predeterminado),autoohost
El iniciador manual lee ~/.openclaw/.env antes de finalizar los valores predeterminados del contenedor/imagen, por lo que puede persistirlos allí.
Si utiliza un OPENCLAW_CONFIG_DIR o un OPENCLAW_WORKSPACE_DIR no predeterminado, establezca las mismas variables tanto para el comando ./scripts/podman/setup.sh como para el posterior comando ./scripts/run-openclaw-podman.sh launch. El iniciador local del repositorio no persiste las anulaciones de ruta personalizada entre shells.
Nota sobre Quadlet:
- El servicio Quadlet generado mantiene intencionalmente una forma predeterminada fija y endurecida: puertos publicados
127.0.0.1,--bind landentro del contenedor y espacio de nombres de usuariokeep-id. - Fija
OPENCLAW_NO_RESPAWN=1,Restart=on-failureyTimeoutStartSec=300. - Publica tanto
127.0.0.1:18789:18789(puerta de enlace) como127.0.0.1:18790:18790(puente). - Lee
~/.openclaw/.envcomoEnvironmentFileen tiempo de ejecución para valores comoOPENCLAW_GATEWAY_TOKEN, pero no consume la lista de permitidos de anulación específica de Podman del iniciador manual. - Si necesita puertos de publicación personalizados, host de publicación u otras opciones de ejecución del contenedor, use el iniciador manual o edite
~/.config/containers/systemd/openclaw.containerdirectamente, luego recargue y reinicie el servicio.
Comandos útiles
Sección titulada «Comandos útiles»- Registros del contenedor:
podman logs -f openclaw - Detener contenedor:
podman stop openclaw - Eliminar contenedor:
podman rm -f openclaw - Abrir URL del panel desde la CLI del host:
openclaw dashboard --no-open - Salud/estado a través de la CLI del host:
openclaw gateway status --deep(sondeo RPC + escaneo de servicio extra)
Solución de problemas
Sección titulada «Solución de problemas»- Permiso denegado (EACCES) en configuración o espacio de trabajo: El contenedor se ejecuta con
--userns=keep-idy--user <your uid>:<your gid>de manera predeterminada. Asegúrese de que las rutas de configuración/espacio de trabajo del host sean propiedad de su usuario actual. - Inicio de la puerta de enlace bloqueado (falta
gateway.mode=local): Asegúrese de que~/.openclaw/openclaw.jsonexista y establezcagateway.mode="local".scripts/podman/setup.shcrea esto si falta. - Los comandos de la CLI del contenedor afectan al objetivo incorrecto: Use
openclaw --container <name> ...explícitamente, o exporteOPENCLAW_CONTAINER=<name>en su shell. openclaw updatefalla con--container: Esperado. Reconstruya/extraiga la imagen, luego reinicie el contenedor o el servicio Quadlet.- El servicio Quadlet no se inicia: Ejecute
systemctl --user daemon-reload, luegosystemctl --user start openclaw.service. En sistemas sin cabeza, también es posible que necesitesudo loginctl enable-linger "$(whoami)". - SELinux bloquea los montajes de enlace: Deje el comportamiento de montaje predeterminado alone; el iniciador agrega automáticamente
:Zen Linux cuando SELinux está aplicando o en modo permisivo.