Actualizar
openclaw update
Sección titulada «openclaw update»Actualice OpenClaw de forma segura y cambie entre los canales estable/beta/desarrollo.
Si instalaste mediante npm/pnpm/bun (instalación global, sin metadatos de git), las actualizaciones ocurren a través del flujo del gestor de paquetes en Actualización.
openclaw updateopenclaw update statusopenclaw update wizardopenclaw update --channel betaopenclaw update --channel devopenclaw update --tag betaopenclaw update --tag mainopenclaw update --dry-runopenclaw update --no-restartopenclaw update --yesopenclaw update --jsonopenclaw --updateOpciones
Sección titulada «Opciones»--no-restart: omite reiniciar el servicio Gateway después de una actualización exitosa. Las actualizaciones del gestor de paquetes que sí reinician el Gateway verifican que el servicio reiniciado reporte la versión actualizada esperada antes de que el comando tenga éxito.--channel <stable|beta|dev>: establece el canal de actualización (git + npm; persistido en la configuración).--tag <dist-tag|version|spec>: anula el objetivo del paquete solo para esta actualización. Para instalaciones de paquetes,mainse mapea agithub:openclaw/openclaw#main.--dry-run: previsualiza las acciones de actualización planificadas (canal/etiqueta/objetivo/flujo de reinicio) sin escribir configuración, instalar, sincronizar complementos o reiniciar.--json: imprime JSONUpdateRunResultlegible por máquina, incluyendopostUpdate.plugins.warningscuando los complementos administrados corruptos o no cargables necesitan reparación después de que la actualización del núcleo tenga éxito, detalles de reserva del complemento del canal beta cuando un complemento no tiene versión beta, ypostUpdate.plugins.integrityDriftscuando se detecta una desviación de artefactos del complemento npm durante la sincronización de complementos posterior a la actualización.--timeout <seconds>: tiempo de espera por paso (por defecto es 1800s).--yes: omite los mensajes de confirmación (por ejemplo confirmación de desactualización).
openclaw update no tiene una opción --verbose. Usa --dry-run para previsualizar
las acciones planificadas de canal/etiqueta/instalación/reinicio, --json para resultados
legibles por máquina y openclaw update status --json cuando solo necesitas detalles del canal y
disponibilidad. Si estás depurando registros de Gateway alrededor de una actualización,
el nivel de detalle de la consola y el nivel de registro de archivo son independientes: --verbose de Gateway afecta
la salida de terminal/WebSocket, mientras que los registros de archivo requieren logging.level: "debug" o
"trace" en la configuración. Consulta Registro de Gateway.
update status
Sección titulada «update status»Muestra el canal de actualización activo + la etiqueta/rama/SHA de git (para checkouts de fuente), además de la disponibilidad de actualización.
openclaw update statusopenclaw update status --jsonopenclaw update status --timeout 10Opciones:
--json: imprime el estado JSON legible por máquina.--timeout <seconds>: tiempo de espera para las comprobaciones (por defecto es 3s).
update wizard
Sección titulada «update wizard»Flujo interactivo para elegir un canal de actualización y confirmar si se debe reiniciar el Gateway
después de actualizar (por defecto se reinicia). Si selecciona dev sin un checkout de git, se
ofrece crear uno.
Opciones:
--timeout <seconds>: tiempo de espera para cada paso de actualización (por defecto1800)
Lo que hace
Sección titulada «Lo que hace»Cuando cambia de canal explícitamente (--channel ...), OpenClaw también mantiene el
método de instalación alineado:
dev→ asegura un checkout de git (por defecto:~/openclaw, anular conOPENCLAW_GIT_DIR), lo actualiza e instala la CLI global desde ese checkout.stable→ instala desde npm usandolatest.beta→ prefiere la etiqueta de distribución de npmbeta, pero recurre alatestcuando beta falta o es más antigua que la versión estable actual.
El actualizador automático del núcleo de Gateway (cuando está habilitado a través de la configuración) inicia la ruta de actualización de la CLI
fuera del controlador de solicitudes en vivo de Gateway. Las actualizaciones del gestor de paquetes update.run del plano de control
también utilizan una transferencia de servicio administrado en lugar de reemplazar el árbol de paquetes
dentro del proceso en vivo de Gateway. Gateway inicia un ayudador separado, se cierra,
y el ayudador ejecuta la ruta normal de la CLI openclaw update --yes --json desde
fuera del árbol de procesos de Gateway. Si esa transferencia no está disponible, update.run
devuelve una respuesta estructurada con el comando de shell seguro para ejecutar manualmente.
Para las instalaciones mediante gestor de paquetes, openclaw update resuelve la versión del paquete objetivo antes de invocar al gestor de paquetes. Las instalaciones globales de npm utilizan una instalación por etapas: OpenClaw instala el nuevo paquete en un prefijo temporal de npm, verifica el inventario del dist empaquetado allí, y luego intercambia ese árbol de paquetes limpio en el prefijo global real. Si la verificación falla, el médico posterior a la actualización, la sincronización de complementos y el trabajo de reinicio no se ejecutan desde el árbol sospechoso. Incluso cuando la versión instalada ya coincide con el objetivo, el comando actualiza la instalación global del paquete, luego ejecuta la sincronización de complementos, una actualización de finalización de comandos principales y el trabajo de reinicio. Esto mantiene los sidecars empaquetados y los registros de complementos propiedad del canal alineados con la compilación instalada de OpenClaw, dejando las reconstrucciones completas de finalización de comandos de complementos para ejecuciones explícitas de openclaw completion --write-state.
Cuando hay un servicio Gateway administrado local instalado y el reinicio está habilitado, las actualizaciones del gestor de paquetes detienen el servicio en ejecución antes de reemplazar el árbol del paquete, luego actualizan los metadatos del servicio desde la instalación actualizada, reinician el servicio y verifican que el Gateway reiniciado informe la versión esperada antes de reportar Gateway: restarted and verified.. En macOS, la verificación posterior a la actualización también verifica que el LaunchAgent esté cargado/en ejecución para el perfil activo y que el puerto de loopback configurado esté saludable. Si el plist está instalado pero launchd no lo está supervisando, OpenClaw re-inicializa el LaunchAgent automáticamente, luego vuelve a ejecutar las comprobaciones de preparación de salud/versión/canal. Una inicialización fresca carga el trabajo RunAtLoad directamente, por lo que la recuperación de la actualización no kickstart -k inmediatamente el Gateway recién generado. Si el Gateway aún no se vuelve saludable, el comando sale con un código distinto de cero e imprime la ruta del registro de reinicio más instrucciones explícitas para reiniciar, reinstalar y revertir el paquete. Si el reinicio no se puede ejecutar, el comando imprime Gateway: restart skipped (...) o Gateway: restart failed: ... con una pista de openclaw gateway restart manual. Con --no-restart, el reemplazo del paquete aún se ejecuta pero el servicio administrado no se detiene ni se reinicia, por lo que el Gateway en ejecución puede conservar código antiguo hasta que lo reinicie manualmente.
Forma de la respuesta del plano de control
Sección titulada «Forma de la respuesta del plano de control»Cuando se invoca update.run a través del plano de control del Gateway en una
instalación mediante administrador de paquetes, el controlador informa el inicio de la transferencia por separado
del la actualización de la CLI que continúa después de que el Gateway sale:
ok: true,result.status: "skipped",result.reason: "managed-service-handoff-started"yhandoff.status: "started"significan que el Gateway creó la transferencia del servicio administrado y programó su propio reinicio para que el asistente separado pueda ejecutaropenclaw update --yes --jsonfuera del proceso del servicio en vivo.ok: false,result.reason: "managed-service-handoff-unavailable"yhandoff.status: "unavailable"significan que OpenClaw no pudo encontrar un límite de servicio supervisor para una transferencia segura. La respuesta incluyehandoff.command, el comando de shell para ejecutar desde fuera del Gateway.ok: false,result.reason: "managed-service-handoff-failed"significa que el Gateway intentó crear la transferencia pero no pudo generar el asistente separado.
El payload sentinel aún se escribe antes de que el Gateway salga, y la transferencia de la CLI
actualiza el mismo centinela de reinicio después de que se completan las comprobaciones de estado del
reinicio del servicio administrado. Durante la transferencia, el centinela puede llevar
stats.reason: "restart-health-pending" sin continuación de éxito; el
Gateway reiniciado sigue sondeándolo y solo dispara la continuación después de que la CLI
ha verificado el estado del servicio y reescrito el centinela con el resultado final ok.
openclaw status y openclaw status --all muestran una fila Update restart
mientras ese centinela está pendiente o fallido, y update.status devuelve el
último centinela en caché.
Flujo de checkout de Git
Sección titulada «Flujo de checkout de Git»Selección de canal
Sección titulada «Selección de canal»stable: haz checkout de la última etiqueta no beta, luego compila y ejecuta doctor.beta: prefiere la última etiqueta-beta, pero recurre a la última etiqueta estable cuando beta falta o es antigua.dev: haz checkout demain, luego busca y haz rebase.
Pasos de actualización
Sección titulada «Pasos de actualización»Verificar árbol de trabajo limpio
Requiere que no haya cambios sin confirmar.
Cambiar de canal
Cambia al canal seleccionado (etiqueta o rama).
Obtener upstream
Solo para desarrolladores.
Compilación previa al vuelo (solo para desarrolladores)
Ejecuta la compilación de TypeScript en un árbol de trabajo temporal. Si la punta falla, retrocede hasta 10 confirmaciones para encontrar la confirmación más reciente que se pueda compilar. Establezca
OPENCLAW_UPDATE_PREFLIGHT_LINT=1para también ejecutar lint durante esta verificación previa; lint se ejecuta en modo serie restringido porque los hosts de actualización del usuario suelen ser más pequeños que los ejecutores de CI.Hacer rebase
Hace rebase sobre la confirmación seleccionada (solo para desarrolladores).
Instalar dependencias
Utiliza el gestor de paquetes del repositorio. Para checkouts de pnpm, el actualizador inicializa
pnpmbajo demanda (primero a través decorepacky luego un respaldo temporalnpm install pnpm@11) en lugar de ejecutarnpm run builddentro de un espacio de trabajo pnpm.Compilar interfaz de usuario de Control
Compila la puerta de enlace y la interfaz de usuario de Control.
Ejecutar doctor
openclaw doctorse ejecuta como la verificación final de actualización segura.Sincronizar complementos
Sincroniza los complementos con el canal activo. El modo de desarrollo utiliza complementos empaquetados; stable y beta utilizan npm. Actualiza las instalaciones de complementos rastreadas.
En el canal de actualización beta, las instalaciones de complementos de npm y ClawHub rastreadas que siguen
la línea predeterminada/más reciente intentan primero una versión @beta del complemento. Si el complemento no tiene
una versión beta, OpenClaw recurre a la especificación predeterminada/más reciente registrada e informa
ello como una advertencia. Para complementos de npm, OpenClaw también recurre cuando el paquete
beta existe pero falla la validación de instalación. Estas advertencias de reserva del complemento no
hacen que la actualización principal falle. Las versiones exactas y las etiquetas explícitas no son
reescritas.
forma abreviada de --update
Sección titulada «forma abreviada de --update»openclaw --update se reescribe como openclaw update (útil para shells y scripts de inicio).
Relacionado
Sección titulada «Relacionado»openclaw doctor(ofrece ejecutar la actualización primero en las comprobaciones de git)- Canales de desarrollo
- Actualización
- Referencia de la CLI