Cron
openclaw cron
Sección titulada «openclaw cron»Administra trabajos de cron para el programador del Gateway.
Sesiones
Sección titulada «Sesiones»--session acepta main, isolated, current o session:<id>.
Claves de sesión
mainse vincula a la sesión principal del agente.isolatedcrea una transcripción y un ID de sesión nuevos para cada ejecución.currentse vincula a la sesión activa en el momento de la creación.- `session:
` se fija a una clave de sesión persistente explícita.
Semántica de sesión aislada
Las ejecuciones aisladas restablecen el contexto de conversación ambiental. El enrutamiento de canales y grupos, la política de envío/cola, la elevación, el origen y el enlace de tiempo de ejecución de ACP se restablecen para la nueva ejecución. Las preferencias seguras y las anulaciones explícitas del modelo o autenticación seleccionadas por el usuario pueden persistir entre ejecuciones.
Entrega
Sección titulada «Entrega»openclaw cron list y openclaw cron show <job-id> obtienen una vista previa de la ruta de entrega resuelta. Para channel: "last", la vista previa muestra si la ruta se resolvió desde la sesión principal o actual, o si fallará cerrada.
Los destinos con prefijo de proveedor pueden desambiguar canales de anuncio no resueltos. Por ejemplo, to: "telegram:123" selecciona Telegram cuando delivery.channel se omite o last. Solo los prefijos anunciados por el complemento cargado son selectores de proveedor. Si delivery.channel es explícito, el prefijo debe coincidir con ese canal; channel: "whatsapp" con to: "telegram:123" se rechaza. Los prefijos de servicio como imessage: y sms: siguen siendo sintaxis de destino propiedad del canal.
Propiedad de la entrega
Sección titulada «Propiedad de la entrega»La entrega de chat cron aislada se comparte entre el agente y el ejecutor:
- El agente puede enviar directamente usando la herramienta
messagecuando hay una ruta de chat disponible. announceentrega la respuesta final solo cuando el agente no envió directamente al objetivo resuelto.webhookpublica el payload finalizado en una URL.nonedeshabilita la entrega de respaldo del ejecutor.
--announce es la entrega de respaldo del ejecutor para la respuesta final. --no-deliver deshabilita ese respaldo pero no elimina la herramienta message del agente cuando hay una ruta de chat disponible.
Los recordatorios creados desde un chat activo conservan el objetivo de entrega del chat en vivo para la entrega de anuncios de reserva. Las claves de sesión internas pueden estar en minúsculas; no las use como una fuente de verdad para los ID de proveedores sensibles a mayúsculas y minúsculas, como los ID de habitación de Matrix.
Entrega de fallos
Sección titulada «Entrega de fallos»Las notificaciones de fallo se resuelven en este orden:
delivery.failureDestinationen el trabajo.cron.failureDestinationglobal.- El objetivo de anuncio principal del trabajo (cuando no se establece un destino de fallo explícito).
Nota: las ejecuciones de cron aisladas tratan los fallos del agente a nivel de ejecución como errores del trabajo incluso cuando no se produce ningún payload de respuesta, por lo que los fallos del modelo/proveedor aún incrementan los contadores de errores y activan las notificaciones de fallo.
Si una ejecución aislada agota el tiempo de espera antes de la primera solicitud al modelo, openclaw cron show
y openclaw cron runs incluyen un error específico de la fase como
setup timed out before runner start o
stalled before first model call (last phase: context-engine).
Para los proveedores basados en CLI, el perro guardián pre-modelo permanece activo hasta que comienza
el turno externo de la CLI, por lo que las búsquedas de sesión, enlaces, autenticación, avisos y bloqueos de configuración de CLI se
reportan como fallos de cron pre-modelo.
Programación
Sección titulada «Programación»Trabajos de una sola vez
Sección titulada «Trabajos de una sola vez»--at <datetime> programa una ejecución única. Las fechas y horas sin desfase se tratan como UTC a menos que también pase --tz <iana>, que interpreta la hora del reloj de pared en la zona horaria dada.
Trabajos recurrentes
Sección titulada «Trabajos recurrentes»Los trabajos recurrentes utilizan un retroceso exponencial de reintentos después de errores consecutivos: 30s, 1m, 5m, 15m, 60m. El programa vuelve a la normalidad después de la próxima ejecución exitosa.
Las ejecuciones omitidas se rastrean por separado de los errores de ejecución. No afectan el retroceso de reintentos, pero openclaw cron edit <job-id> --failure-alert-include-skipped puede optar por las alertas de fallo para notificaciones repetidas de ejecuciones omitidas.
Para trabajos aislados que tienen como objetivo un proveedor de modelo configurado localmente, cron ejecuta una verificación previa ligera del proveedor antes de iniciar el turno del agente. Los proveedores de Loopback, red privada y .local api: "ollama" se sondean en /api/tags; los proveedores locales compatibles con OpenAI, como vLLM, SGLang y LM Studio, se sondean en /models. Si el punto final es inalcanzable, la ejecución se registra como skipped y se reintenta en un horario posterior; los puntos finales muertos coincidentes se almacenan en caché durante 5 minutos para evitar que muchos trabajos sobrecarguen el mismo servidor local.
Nota: las definiciones de trabajos cron residen en jobs.json, mientras que el estado de tiempo de ejecución pendiente reside en jobs-state.json. Si jobs.json se edita externamente, Gateway vuelve a cargar los horarios modificados y borra las ranuras pendientes obsoletas; las reescrituras que solo cambian el formato no borran la ranura pendiente.
Ejecuciones manuales
Sección titulada «Ejecuciones manuales»openclaw cron run <job-id> fuerza la ejecución de forma predeterminada y regresa tan pronto como la ejecución manual se pone en la cola. Las respuestas exitosas incluyen { ok: true, enqueued: true, runId }. Use el runId devuelto para inspeccionar el resultado posterior:
openclaw cron run <job-id>openclaw cron runs --id <job-id> --run-id <run-id>Agregue --wait cuando un script debe bloquearse hasta que esa ejecución en cola específica registre un estado terminal:
openclaw cron run <job-id> --wait --wait-timeout 10m --poll-interval 2sCon --wait, la CLI todavía llama primero a cron.run y luego sondea cron.runs para el runId devuelto. El comando sale 0 solo cuando la ejecución finaliza con el estado ok. Sale con un valor distinto de cero cuando la ejecución finaliza con error o skipped, cuando la respuesta de Gateway no incluye un runId, o cuando --wait-timeout expira. --poll-interval debe ser mayor que cero.
Modelos
Sección titulada «Modelos»cron add|edit --model <ref> selecciona un modelo permitido para el trabajo.
Cron --model es un job primary, no una anulación de chat-session /model. Esto significa:
- Los modelos de respaldo configurados aún se aplican cuando falla el modelo de trabajo seleccionado.
- El payload por trabajo
fallbacksreemplaza la lista de respaldo configurada cuando está presente. - Una lista de respaldo vacía por trabajo (
fallbacks: []en el payload/API del trabajo) hace que la ejecución de cron sea estricta. - Cuando un trabajo tiene
--modelpero no se configura ninguna lista de respaldo, OpenClaw pasa una anulación de respaldo vacía explícita para que el agente primario no se agregue como un objetivo de reintento oculto.
openclaw doctor informa de los trabajos que ya tienen payload.model establecido, incluyendo recuentos de espacios de nombres del proveedor e incoincidencias con agents.defaults.model. Use esa verificación cuando el comportamiento de autenticación, proveedor o facturación se vea diferente entre el chat en vivo y los trabajos programados.
Precedencia del modelo cron aislado
Sección titulada «Precedencia del modelo cron aislado»Cron aislado resuelve el modelo activo en este orden:
- Anulación de Gmail-hook.
- Por trabajo
--model. - Anulación de modelo de sesión cron almacenada (cuando el usuario seleccionó uno).
- Selección de modelo de agente o predeterminado.
Modo rápido
Sección titulada «Modo rápido»El modo rápido de cron aislado sigue la selección del modelo en vivo resuelta. La configuración del modelo params.fastMode se aplica de manera predeterminada, pero una anulación de sesión almacenada fastMode todavía tiene prioridad sobre la configuración.
Reintentos de cambio de modelo en vivo
Sección titulada «Reintentos de cambio de modelo en vivo»Si una ejecución aislada lanza LiveSessionModelSwitchError, cron mantiene el proveedor y modelo cambiados (y la anulación del perfil de autenticación cambiado cuando está presente) para la ejecución activa antes de reintentar. El bucle de reinterno externo está limitado a dos reintentos de cambio después del intento inicial, luego aborta en lugar de buclear para siempre.
Salida de ejecución y denegaciones
Sección titulada «Salida de ejecución y denegaciones»Supresión de reconocimiento obsoleto
Sección titulada «Supresión de reconocimiento obsoleto»Cron aislado activa la supresión de respuestas de reconocimiento obsoleto únicamente. Si el primer resultado es solo una actualización de estado interina y ninguna ejecución de subagente descendente es responsable de la respuesta final, cron vuelve a preguntar una vez para el resultado real antes de la entrega.
Supresión silenciosa de tokens
Sección titulada «Supresión silenciosa de tokens»Si una ejecución aislada de cron devuelve solo el token silencioso (NO_REPLY o no_reply), cron suprime tanto la entrega directa de salida como la ruta de resumen en cola de respaldo, por lo que no se publica nada de vuelta en el chat.
Denegaciones estructuradas
Sección titulada «Denegaciones estructuradas»Las ejecuciones aisladas de cron utilizan metadatos estructurados de denegación de ejecución de la ejecución incrustada como la señal de denegación autorizada. También respetan los contenedores UNAVAILABLE del nodo host cuando el mensaje de error estructurado anidado comienza con SYSTEM_RUN_DENIED o INVALID_REQUEST.
Cron no clasifica la prosa de salida final ni las frases de rechazo que parecen aprobación como denegaciones, a menos que la ejecución incrustada también proporcione metadatos de denegación estructurada, por lo que el texto ordinario del asistente no se trata como un comando bloqueado.
cron list y el historial de ejecuciones muestran el motivo de la denegación en lugar de informar un comando bloqueado como ok.
Retención
Sección titulada «Retención»La retención y la poda se controlan en la configuración:
cron.sessionRetention(por defecto24h) poda las sesiones de ejecución aisladas completadas.cron.runLog.maxBytesycron.runLog.keepLinespodan~/.openclaw/cron/runs/<jobId>.jsonl.
Migración de trabajos antiguos
Sección titulada «Migración de trabajos antiguos»Ediciones comunes
Sección titulada «Ediciones comunes»Actualizar la configuración de entrega sin cambiar el mensaje:
openclaw cron edit <job-id> --announce --channel telegram --to "123456789"Deshabilitar la entrega para un trabajo aislado:
openclaw cron edit <job-id> --no-deliverHabilitar el contexto de arranque ligero para un trabajo aislado:
openclaw cron edit <job-id> --light-contextAnunciar en un canal específico:
openclaw cron edit <job-id> --announce --channel slack --to "channel:C1234567890"Anunciar en un tema de foro de Telegram:
openclaw cron edit <job-id> --announce --channel telegram --to "-1001234567890" --thread-id 42Crear un trabajo aislado con contexto de arranque ligero:
openclaw cron add \ --name "Lightweight morning brief" \ --cron "0 7 * * *" \ --session isolated \ --message "Summarize overnight updates." \ --light-context \ --no-deliver--light-context se aplica solo a trabajos aislados de turno de agente. Para las ejecuciones de cron, el modo ligero mantiene el contexto de arranque vacío en lugar de inyectar el conjunto de arranque completo del espacio de trabajo.
Comandos comunes de administración
Sección titulada «Comandos comunes de administración»Ejecución manual e inspección:
openclaw cron listopenclaw cron list --agent opsopenclaw cron get <job-id>openclaw cron show <job-id>openclaw cron run <job-id>openclaw cron run <job-id> --dueopenclaw cron run <job-id> --wait --wait-timeout 10mopenclaw cron run <job-id> --wait --wait-timeout 10m --poll-interval 2sopenclaw cron runs --id <job-id> --limit 50openclaw cron runs --id <job-id> --run-id <run-id>openclaw cron list muestra todos los trabajos coincidentes de manera predeterminada. Pase --agent <id> para mostrar solo los trabajos cuyo ID de agente normalizado efectivo coincida; los trabajos sin un ID de agente almacenado cuentan como el agente predeterminado configurado.
openclaw cron get <job-id> devuelve el JSON del trabajo almacenado directamente. Use cron show <job-id> cuando desee la vista legible por humanos con la vista previa de la ruta de entrega.
cron list --json y cron show <job-id> --json incluyen un campo status de nivel superior en cada trabajo, calculado a partir de enabled, state.runningAtMs y state.lastRunStatus. Valores: disabled, running, ok, error, skipped o idle. Esto refleja la columna de estado legible por humanos para que las herramientas externas puedan leer el estado del trabajo sin volver a derivarlo.
Las entradas cron runs incluyen diagnósticos de entrega con el objetivo cron previsto, el objetivo resuelto, los envíos de la herramienta de mensajes, el uso de reserva y el estado de entrega.
Redirección de agente y sesión:
openclaw cron edit <job-id> --agent opsopenclaw cron edit <job-id> --clear-agentopenclaw cron edit <job-id> --session currentopenclaw cron edit <job-id> --session "session:daily-brief"openclaw cron add advierte cuando --agent se omite en los trabajos de turno de agente y vuelve al agente predeterminado (main). Pase --agent <id> en el momento de la creación para fijar un agente específico.
Ajustes de entrega:
openclaw cron edit <job-id> --announce --channel slack --to "channel:C1234567890"openclaw cron edit <job-id> --best-effort-deliveropenclaw cron edit <job-id> --no-best-effort-deliveropenclaw cron edit <job-id> --no-deliver