Latido (Gateway)
¿Latido o cron? Consulta Automatización y tareas para obtener orientación sobre cuándo usar cada uno.Latido ejecuta turnos periódicos del agente en la sesión principal para que el modelo pueda mostrar cualquier cosa que necesite atención sin enviarte spam. Latido 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 latidos habilitados (el valor predeterminado es
30m, o1hpara autenticación OAuth/token de Anthropic, incluido el reuso de Claude CLI) o establece tu propia cadencia. - Crea una pequeña lista de comprobación en
HEARTBEAT.mdo un bloquetasks:en el espacio de trabajo del agente (opcional, pero recomendado). - Decide a dónde deben ir los mensajes de latido (
target: "none"es el valor predeterminado; establecetarget: "last"para enrutar al último contacto). - Opcional: habilita la entrega del razonamiento del latido para mayor transparencia.
- Opcional: usa contexto de arranque ligero si las ejecuciones de latido solo necesitan
HEARTBEAT.md. - Opcional: habilita sesiones aisladas para evitar enviar el historial completo de la conversación en cada latido.
- Opcional: restringe los latidos a horas activas (hora local).
Valores predeterminados
- Intervalo:
30m(o1hcuando el modo de autenticación detectado es OAuth/token de Anthropic, incluido el reuso de Claude CLI). Estableceagents.defaults.heartbeat.everyoagents.list[].heartbeat.every; usa0mpara deshabilitarlo. - 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 latido se envía textualmente como mensaje de usuario. El prompt del sistema incluye una sección “Heartbeat” solo cuando los latidos están habilitados para el agente predeterminado, y la ejecución está marcada internamente.
- Cuando los latidos están deshabilitados con
0m, las ejecuciones normales también omitenHEARTBEAT.mddel contexto de arranque para que el modelo no vea instrucciones solo para latidos. - Las horas activas (
heartbeat.activeHours) se comprueban en la zona horaria configurada. Fuera de esa ventana, los latidos se omiten hasta el siguiente tick dentro de la ventana.
Para qué sirve el prompt de latido
El prompt predeterminado es intencionalmente amplio:- Tareas en segundo plano: “Consider outstanding tasks” impulsa al agente a revisar seguimientos (bandeja de entrada, calendario, recordatorios, trabajo en cola) y mostrar cualquier cosa urgente.
- Verificación con la persona: “Checkup sometimes on your human during day time” impulsa un mensaje ligero ocasional de “¿necesitas algo?”, pero evita el 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 textualmente).
Contrato de respuesta
- Si nada necesita atención, responde con
HEARTBEAT_OK. - Durante las ejecuciones de latido, OpenClaw trata
HEARTBEAT_OKcomo un acuse de recibo 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 aislado al inicio o al 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 del latido.agents.list[].heartbeatse fusiona por encima; si algún agente tiene un bloqueheartbeat, solo esos agentes ejecutan latidos.channels.defaults.heartbeatestablece los valores predeterminados de visibilidad para todos los canales.channels.<channel>.heartbeatsobrescribe los valores predeterminados del canal.channels.<channel>.accounts.<id>.heartbeat(canales con varias cuentas) sobrescribe por canal.
Latidos por agente
Si alguna entrada deagents.list[] incluye un bloque heartbeat, solo esos agentes
ejecutan latidos. El bloque por agente se fusiona por encima de agents.defaults.heartbeat
(así puedes establecer valores compartidos una vez y sobrescribir por agente).
Ejemplo: dos agentes, solo el segundo agente ejecuta latidos.
Ejemplo de horas activas
Restringe los latidos al horario laboral en una zona horaria específica:Configuración 24/7
Si quieres que los latidos se ejecuten 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 ancho cero, por lo que los latidos siempre se omiten.
Ejemplo de varias cuentas
UsaaccountId para apuntar a una cuenta específica en canales con varias cuentas como Telegram:
Notas de campos
every: intervalo del latido (cadena de duración; la unidad predeterminada = minutos).model: sobrescritura opcional del modelo para ejecuciones de latido (provider/model).includeReasoning: cuando está habilitado, también entrega el mensaje separadoReasoning:cuando está disponible (misma forma que/reasoning on).lightContext: cuando es true, las ejecuciones de latido usan contexto de arranque ligero y conservan soloHEARTBEAT.mdde los archivos de arranque del espacio de trabajo.isolatedSession: cuando es true, cada latido se ejecuta en una sesión nueva sin historial de conversación previa. Usa el mismo patrón de aislamiento que cronsessionTarget: "isolated". Reduce drásticamente el costo de tokens por latido. 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 latido.main(predeterminado): sesión principal del agente.- Clave de sesión explícita (cópiala desde
openclaw sessions --jsono desde 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 el latido, pero no lo entrega externamente.
directPolicy: controla el comportamiento de entrega directa/MD:allow(predeterminado): permite la entrega directa/MD de latidos.block: suprime la entrega directa/MD (reason=dm-blocked).
to: sobrescritura 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: sobrescribe el cuerpo del prompt predeterminado (no se fusiona).ackMaxChars: máximo de caracteres permitidos después deHEARTBEAT_OKantes de la entrega.suppressToolErrorWarnings: cuando es true, suprime las cargas útiles de advertencia de errores de herramientas durante las ejecuciones de latido.activeHours: restringe las ejecuciones de latido a una ventana horaria. Objeto constart(HH:MM, inclusivo; usa00:00para el inicio del día),end(HH:MM exclusivo;24:00permitido para el final del día) ytimezoneopcional.- Omitido o
"user": usa tuagents.defaults.userTimezonesi está establecido; 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"anterior. startyendno deben ser iguales para una ventana activa; los valores iguales se tratan como ancho cero (siempre fuera de la ventana).- Fuera de la ventana activa, los latidos se omiten hasta el siguiente tick dentro de la ventana.
- Omitido o
Comportamiento de entrega
- Los latidos se ejecutan en la sesión principal del agente de forma predeterminada (
agent:<id>:<mainKey>), o englobalcuandosession.scope = "global". Establecesessionpara sobrescribir a una sesión de canal específica (Discord/WhatsApp/etc.). sessionsolo afecta el contexto de ejecución; la entrega se controla contargetyto.- 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 latido permiten destinos directos/MD de forma predeterminada. Establece
directPolicy: "block"para suprimir los envíos a destinos directos mientras se sigue ejecutando el turno de latido. - Si la cola principal está ocupada, el latido se omite y se reintenta más tarde.
- Si
targetno se resuelve en ningún destino externo, la ejecución igualmente ocurre, pero no se envía ningún mensaje saliente. - Si
showOk,showAlertsyuseIndicatorestán todos deshabilitados, la ejecución se omite de entrada comoreason=alerts-disabled. - Si solo la entrega de alertas está deshabilitada, OpenClaw aún puede ejecutar el latido, actualizar las marcas de tiempo de tareas vencidas, restaurar la marca de tiempo de inactividad de la sesión y suprimir la carga útil de alerta hacia el exterior.
- Las respuestas exclusivas de latido no mantienen la sesión activa; se restaura el último
updatedAtpara que la expiración por inactividad se comporte con normalidad. - Las tareas en segundo plano desacopladas pueden poner en cola un evento del sistema y activar el latido cuando la sesión principal debe notar algo rápidamente. Esa activación no hace que el latido ejecute una tarea en segundo plano.
Controles de visibilidad
De forma predeterminada, los acuses de reciboHEARTBEAT_OK se suprimen, mientras que el contenido de alerta sí
se entrega. Puedes ajustarlo por canal o por cuenta:
Qué hace cada indicador
showOk: envía un acuse de reciboHEARTBEAT_OKcuando el modelo devuelve una respuesta que solo contiene 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 interfaz.
Ejemplos por canal frente a por cuenta
Patrones comunes
| Objetivo | Configuración |
|---|---|
| Comportamiento predeterminado (OK silenciosos, alertas activadas) | (no se necesita configuración) |
| Totalmente silencioso (sin mensajes ni 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 archivoHEARTBEAT.md en el espacio de trabajo, el prompt predeterminado le indica al
agente que lo lea. Piensa en él como tu “lista de comprobación de latido”: pequeña, estable y
segura para incluirla cada 30 minutos.
En las ejecuciones normales, HEARTBEAT.md solo se inyecta cuando la guía de latido está
habilitada para el agente predeterminado. Deshabilitar la cadencia del latido con 0m o
establecer includeSystemPromptSection: false lo omite del contexto de arranque
normal.
Si HEARTBEAT.md existe pero está efectivamente vacío (solo líneas en blanco y encabezados
Markdown como # Heading), OpenClaw omite la ejecución del latido para ahorrar llamadas a la API.
Esa omisión se informa como reason=empty-heartbeat-file.
Si el archivo no existe, el latido igualmente se ejecuta y el modelo decide qué hacer.
Mantenlo pequeño (lista de comprobación corta o recordatorios) 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 latido.
Ejemplo:
- OpenClaw analiza el bloque
tasks:y comprueba cada tarea según su propiointerval. - Solo las tareas vencidas se incluyen en el prompt de latido para ese tick.
- Si no hay tareas vencidas, el latido se omite por completo (
reason=no-tasks-due) para evitar una llamada al modelo desperdiciada. - El contenido que no es tarea en
HEARTBEAT.mdse conserva y se añade como contexto adicional después de la lista de tareas vencidas. - Las marcas de tiempo de última ejecución de las tareas se almacenan en el estado de la 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 latido completa su ruta normal de respuesta. Las ejecuciones omitidas por
empty-heartbeat-file/no-tasks-dueno marcan las 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 agregar una revisión diaria del calendario.” - “Reescribe
HEARTBEAT.mdpara que sea más corto y se centre 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 latido inmediato con:heartbeat configurado, una activación manual ejecuta inmediatamente los
latidos de cada uno de esos agentes.
Usa --mode next-heartbeat para esperar al siguiente tick programado.
Entrega de razonamiento (opcional)
De forma predeterminada, los latidos entregan solo la carga útil final de “respuesta”. Si quieres transparencia, habilita:agents.defaults.heartbeat.includeReasoning: true
Reasoning: (misma forma que /reasoning on). Esto puede ser útil cuando el agente
está gestionando varias sesiones/codexes y quieres ver por qué decidió hacerte
ping, pero también puede revelar más detalle interno del que quieres. Es preferible mantenerlo
desactivado en chats grupales.
Consideraciones de costo
Los latidos ejecutan turnos completos del agente. Los intervalos más cortos consumen más tokens. Para reducir el costo:- Usa
isolatedSession: truepara evitar enviar el historial completo de conversación (de ~100K tokens a ~2-5K por ejecución). - Usa
lightContext: truepara limitar los archivos de arranque únicamente aHEARTBEAT.md. - Establece un
modelmás económico (por ejemplo,ollama/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
- Timezone — cómo la zona horaria afecta la programación del latido
- Solución de problemas — depuración de problemas de automatización