Heartbeat (Gateway)
¿Heartbeat o cron? Consulta Automatización y tareas para orientarte sobre cuándo usar cada uno.Heartbeat ejecuta turnos periódicos del agente en la sesión principal para que el modelo pueda mostrar cualquier cosa que requiera atención sin enviarte spam. Heartbeat es un turno programado de la sesión principal: no crea registros de tareas en segundo plano. Los registros de tareas son para trabajo desacoplado (ejecuciones de ACP, subagentes, trabajos cron aislados). Solución de problemas: Tareas programadas
Inicio rápido (principiante)
- Deja los heartbeat habilitados (el valor predeterminado es
30m, o1hpara autenticación Anthropic OAuth/token, incluida la reutilización de Claude CLI) o establece tu propia cadencia. - Crea una pequeña lista de verificación
HEARTBEAT.mdo un bloquetasks:en el espacio de trabajo del agente (opcional, pero recomendado). - Decide adónde deben ir los mensajes de heartbeat (
target: "none"es el valor predeterminado; establecetarget: "last"para enrutar al último contacto). - Opcional: habilita la entrega del razonamiento de heartbeat para mayor transparencia.
- Opcional: usa contexto de bootstrap ligero si las ejecuciones de heartbeat solo necesitan
HEARTBEAT.md. - Opcional: habilita sesiones aisladas para evitar enviar el historial completo de la conversación en cada heartbeat.
- Opcional: restringe heartbeat a las horas activas (hora local).
Valores predeterminados
- Intervalo:
30m(o1hcuando Anthropic OAuth/token es el modo de autenticación detectado, incluida la reutilización de Claude CLI). Estableceagents.defaults.heartbeat.everyoagents.list[].heartbeat.every; usa0mpara desactivar. - Cuerpo del prompt (configurable mediante
agents.defaults.heartbeat.prompt):Read HEARTBEAT.md if it exists (workspace context). Follow it strictly. Do not infer or repeat old tasks from prior chats. If nothing needs attention, reply HEARTBEAT_OK. - El prompt de heartbeat se envía literalmente como mensaje del usuario. El prompt del sistema incluye una sección “Heartbeat” y la ejecución se marca internamente.
- Las horas activas (
heartbeat.activeHours) se comprueban en la zona horaria configurada. Fuera de la ventana, los heartbeat se omiten hasta el siguiente tick dentro de la ventana.
Para qué sirve el prompt de heartbeat
El prompt predeterminado es intencionalmente amplio:- Tareas en segundo plano: “Consider outstanding tasks” empuja al agente a revisar seguimientos (bandeja de entrada, calendario, recordatorios, trabajo en cola) y mostrar cualquier cosa urgente.
- Comprobación con el humano: “Checkup sometimes on your human during day time” impulsa una comprobación ligera ocasional de “¿necesitas algo?”, pero evita spam nocturno usando tu zona horaria local configurada (consulta /concepts/timezone).
agents.defaults.heartbeat.prompt (o
agents.list[].heartbeat.prompt) con un cuerpo personalizado (enviado literalmente).
Contrato de respuesta
- Si nada requiere atención, responde con
HEARTBEAT_OK. - Durante las ejecuciones de heartbeat, OpenClaw trata
HEARTBEAT_OKcomo confirmación cuando aparece al inicio o al final de la respuesta. El token se elimina y la respuesta se descarta si el contenido restante es ≤ackMaxChars(predeterminado: 300). - Si
HEARTBEAT_OKaparece en la mitad de una respuesta, no se trata de forma especial. - Para alertas, no incluyas
HEARTBEAT_OK; devuelve solo el texto de la alerta.
HEARTBEAT_OK suelto al inicio/final de un mensaje se elimina
y se registra; un mensaje que sea solo HEARTBEAT_OK se descarta.
Configuración
Alcance y precedencia
agents.defaults.heartbeatestablece el comportamiento global de heartbeat.agents.list[].heartbeatse fusiona por encima; si algún agente tiene un bloqueheartbeat, solo esos agentes ejecutan heartbeat.channels.defaults.heartbeatestablece valores predeterminados de visibilidad para todos los canales.channels.<channel>.heartbeatanula los valores predeterminados del canal.channels.<channel>.accounts.<id>.heartbeat(canales con varias cuentas) anula la configuración por canal.
Heartbeats por agente
Si alguna entrada deagents.list[] incluye un bloque heartbeat, solo esos agentes
ejecutan heartbeat. El bloque por agente se fusiona sobre agents.defaults.heartbeat
(así puedes establecer valores compartidos una sola vez y anularlos por agente).
Ejemplo: dos agentes; solo el segundo ejecuta heartbeat.
Ejemplo de horas activas
Restringe heartbeat al horario laboral en una zona horaria específica:Configuración 24/7
Si quieres que heartbeat se ejecute todo el día, usa uno de estos patrones:- Omite
activeHourspor completo (sin restricción de ventana horaria; este es el comportamiento predeterminado). - Establece una ventana de día completo:
activeHours: { start: "00:00", end: "24:00" }.
start y end (por ejemplo 08:00 a 08:00).
Eso se trata como una ventana de anchura cero, por lo que heartbeat siempre se omite.
Ejemplo de varias cuentas
UsaaccountId para apuntar a una cuenta específica en canales con varias cuentas como Telegram:
Notas sobre los campos
every: intervalo de heartbeat (cadena de duración; unidad predeterminada = minutos).model: anulación opcional de modelo para ejecuciones de heartbeat (provider/model).includeReasoning: cuando está habilitado, también entrega el mensajeReasoning:separado cuando está disponible (con la misma forma que/reasoning on).lightContext: cuando es true, las ejecuciones de heartbeat usan contexto de bootstrap ligero y conservan soloHEARTBEAT.mdde los archivos de bootstrap del espacio de trabajo.isolatedSession: cuando es true, cada heartbeat se ejecuta en una sesión nueva sin historial previo de conversación. Usa el mismo patrón de aislamiento que cronsessionTarget: "isolated". Reduce drásticamente el costo en tokens por heartbeat. Combínalo conlightContext: truepara obtener el máximo ahorro. El enrutamiento de entrega sigue usando el contexto de la sesión principal.session: clave de sesión opcional para ejecuciones de heartbeat.main(predeterminado): sesión principal del agente.- Clave de sesión explícita (cópiala de
openclaw sessions --jsono de la CLI de sesiones). - Formatos de clave de sesión: consulta Sesiones y Grupos.
target:last: entrega al último canal externo usado.- canal explícito: cualquier canal configurado o id de plugin, por ejemplo
discord,matrix,telegramowhatsapp. none(predeterminado): ejecuta heartbeat pero no entrega nada externamente.
directPolicy: controla el comportamiento de entrega directa/DM:allow(predeterminado): permite la entrega directa/DM de heartbeat.block: suprime la entrega directa/DM (reason=dm-blocked).
to: anulación opcional del destinatario (id específico del canal, por ejemplo E.164 para WhatsApp o un id de chat de Telegram). Para temas/hilos de Telegram, usa<chatId>:topic:<messageThreadId>.accountId: id de cuenta opcional para canales con varias cuentas. Cuandotarget: "last", el id de cuenta se aplica al último canal resuelto si admite cuentas; de lo contrario, se ignora. Si el id de cuenta no coincide con una cuenta configurada para el canal resuelto, la entrega se omite.prompt: anula el cuerpo de prompt predeterminado (no se fusiona).ackMaxChars: número máximo de caracteres permitidos después deHEARTBEAT_OKantes de la entrega.suppressToolErrorWarnings: cuando es true, suprime las cargas útiles de advertencia de error de herramientas durante las ejecuciones de heartbeat.activeHours: restringe las ejecuciones de heartbeat a una ventana horaria. Objeto constart(HH:MM, inclusivo; usa00:00para el inicio del día),end(HH:MM exclusivo;24:00permitido para el fin del día) ytimezoneopcional.- Omitido o
"user": usa tuagents.defaults.userTimezonesi está definida; de lo contrario, recurre a la zona horaria del sistema host. "local": siempre usa la zona horaria del sistema host.- Cualquier identificador IANA (por ejemplo
America/New_York): se usa directamente; si no es válido, recurre al comportamiento de"user"descrito arriba. startyendno deben ser iguales para una ventana activa; valores iguales se tratan como anchura cero (siempre fuera de la ventana).- Fuera de la ventana activa, los heartbeat se omiten hasta el siguiente tick dentro de la ventana.
- Omitido o
Comportamiento de entrega
- Heartbeat se ejecuta en la sesión principal del agente por defecto (
agent:<id>:<mainKey>), o englobalcuandosession.scope = "global". Establecesessionpara anularlo a una sesión de canal específica (Discord/WhatsApp/etc.). sessionsolo afecta el contexto de ejecución; la entrega está controlada portargetyto.- Para entregar a un canal/destinatario específico, establece
target+to. Contarget: "last", la entrega usa el último canal externo de esa sesión. - Las entregas de heartbeat permiten destinos directos/DM de forma predeterminada. Establece
directPolicy: "block"para suprimir envíos a destinos directos sin dejar de ejecutar el turno de heartbeat. - Si la cola principal está ocupada, el heartbeat se omite y se reintenta más tarde.
- Si
targetno se resuelve a ningún destino externo, la ejecución sigue ocurriendo pero no se envía ningún mensaje saliente. - Si
showOk,showAlertsyuseIndicatorestán todos desactivados, la ejecución se omite desde el principio comoreason=alerts-disabled. - Si solo está desactivada la entrega de alertas, OpenClaw aún puede ejecutar heartbeat, actualizar las marcas de tiempo de tareas vencidas, restaurar la marca de tiempo de inactividad de la sesión y suprimir la carga útil externa de la alerta.
- Las respuestas solo de heartbeat no mantienen viva la sesión; el último
updatedAtse restaura para que la caducidad por inactividad se comporte con normalidad. - Las tareas en segundo plano desacopladas pueden poner en cola un evento del sistema y activar heartbeat cuando la sesión principal debe notar algo rápidamente. Esa activación no hace que heartbeat se convierta en una tarea en segundo plano.
Controles de visibilidad
De forma predeterminada, las confirmacionesHEARTBEAT_OK se suprimen mientras que el contenido de alerta
se entrega. Puedes ajustar esto por canal o por cuenta:
Qué hace cada indicador
showOk: envía una confirmaciónHEARTBEAT_OKcuando el modelo devuelve una respuesta solo de OK.showAlerts: envía el contenido de la alerta cuando el modelo devuelve una respuesta distinta de OK.useIndicator: emite eventos de indicador para superficies de estado de la IU.
Ejemplos por canal frente a por cuenta
Patrones comunes
| Objetivo | Configuración |
|---|---|
| Comportamiento predeterminado (OK silenciosos, alertas activadas) | (no se necesita configuración) |
| Completamente silencioso (sin mensajes, sin indicador) | channels.defaults.heartbeat: { showOk: false, showAlerts: false, useIndicator: false } |
| Solo indicador (sin mensajes) | channels.defaults.heartbeat: { showOk: false, showAlerts: false, useIndicator: true } |
| OK solo en un canal | channels.telegram.heartbeat: { showOk: true } |
HEARTBEAT.md (opcional)
Si existe un archivo HEARTBEAT.md en el espacio de trabajo, el prompt predeterminado le indica al
agente que lo lea. Piensa en él como tu “lista de verificación de heartbeat”: pequeño, estable y
seguro para incluir cada 30 minutos.
Si HEARTBEAT.md existe pero está efectivamente vacío (solo líneas en blanco y encabezados de Markdown
como # Heading), OpenClaw omite la ejecución de heartbeat para ahorrar llamadas API.
Esa omisión se informa como reason=empty-heartbeat-file.
Si el archivo no existe, heartbeat sigue ejecutándose y el modelo decide qué hacer.
Mantenlo pequeño (lista de verificación o recordatorios breves) para evitar inflar el prompt.
Ejemplo de HEARTBEAT.md:
Bloques tasks:
HEARTBEAT.md también admite un pequeño bloque estructurado tasks: para comprobaciones
basadas en intervalos dentro del propio heartbeat.
Ejemplo:
- OpenClaw analiza el bloque
tasks:y comprueba cada tarea con su propiointerval. - Solo las tareas vencidas se incluyen en el prompt de heartbeat de ese tick.
- Si no hay tareas vencidas, heartbeat se omite por completo (
reason=no-tasks-due) para evitar una llamada inútil al modelo. - El contenido que no pertenece a tareas en
HEARTBEAT.mdse conserva y se añade como contexto adicional después de la lista de tareas vencidas. - Las marcas de tiempo de la última ejecución de las tareas se almacenan en el estado de sesión (
heartbeatTaskState), por lo que los intervalos sobreviven a reinicios normales. - Las marcas de tiempo de las tareas solo avanzan después de que una ejecución de heartbeat completa su ruta normal de respuesta. Las ejecuciones omitidas
empty-heartbeat-file/no-tasks-dueno marcan tareas como completadas.
¿Puede el agente actualizar HEARTBEAT.md?
Sí, si se lo pides.
HEARTBEAT.md es simplemente un archivo normal en el espacio de trabajo del agente, así que puedes decirle al
agente (en un chat normal) algo como:
- “Actualiza
HEARTBEAT.mdpara añadir una comprobación diaria del calendario.” - “Reescribe
HEARTBEAT.mdpara que sea más corto y esté centrado en seguimientos de la bandeja de entrada.”
HEARTBEAT.md, ya que pasa a formar parte del contexto del prompt.
Activación manual (bajo demanda)
Puedes poner en cola un evento del sistema y activar un heartbeat inmediato con:heartbeat configurado, una activación manual ejecuta inmediatamente
cada uno de esos heartbeat de agente.
Usa --mode next-heartbeat para esperar al siguiente tick programado.
Entrega de razonamiento (opcional)
De forma predeterminada, los heartbeat entregan solo la carga útil final de “respuesta”. Si quieres transparencia, habilita:agents.defaults.heartbeat.includeReasoning: true
Reasoning: (con la misma forma que /reasoning on). Esto puede ser útil cuando el agente
está gestionando varias sesiones/codexes y quieres ver por qué decidió enviarte un mensaje,
pero también puede filtrar más detalles internos de los que quieres. Es preferible mantenerlo
desactivado en chats de grupo.
Consideraciones de costo
Los heartbeat ejecutan turnos completos del agente. Los intervalos más cortos consumen más tokens. Para reducir costo:- Usa
isolatedSession: truepara evitar enviar todo el historial de conversación (~100K tokens bajan a ~2-5K por ejecución). - Usa
lightContext: truepara limitar los archivos de bootstrap solo aHEARTBEAT.md. - Establece un
modelmás barato (por ejemploollama/llama3.2:1b). - Mantén
HEARTBEAT.mdpequeño. - Usa
target: "none"si solo quieres actualizaciones de estado internas.
Relacionado
- Automatización y tareas — todos los mecanismos de automatización de un vistazo
- Tareas en segundo plano — cómo se rastrea el trabajo desacoplado
- Zona horaria — cómo afecta la zona horaria a la programación de heartbeat
- Solución de problemas — depuración de problemas de automatización