Ir al contenido

Registro

OpenClaw tiene dos superficies principales de registro:

  • Archivos de registro (líneas JSON) escritos por el Gateway.
  • Salida de consola que se muestra en terminales y en la interfaz de depuración del Gateway.

La pestaña Registros de la interfaz de control realiza un seguimiento del archivo de registro del gateway. Esta página explica dónde residen los registros, cómo leerlos y cómo configurar los niveles y formatos de registro.

De forma predeterminada, el Gateway escribe un archivo de registro rotativo en:

/tmp/openclaw/openclaw-YYYY-MM-DD.log

La fecha usa la zona horaria local del host del gateway.

Cada archivo rota cuando alcanza logging.maxFileBytes (predeterminado: 100 MB). OpenClaw conserva hasta cinco archivos numerados junto al archivo activo, como openclaw-YYYY-MM-DD.1.log, y sigue escribiendo en un registro activo nuevo en lugar de suprimir los diagnósticos.

Puede anular esto en ~/.openclaw/openclaw.json:

{
"logging": {
"file": "/path/to/openclaw.log"
}
}

Usa la CLI para hacer un seguimiento del archivo de registro de la puerta de enlace a través de RPC:

Ventana de terminal
openclaw logs --follow

Opciones actuales útiles:

  • --local-time: renderiza las marcas de tiempo en su zona horaria local
  • --url <url> / --token <token> / --timeout <ms>: indicadores estándar de RPC del Gateway
  • --expect-final: indicador de espera de respuesta final de RPC respaldado por agente (aceptado aquí a través de la capa de cliente compartida)

Modos de salida:

  • Sesiones TTY: líneas de registro estructuradas, con colores y bonitas.
  • Sesiones que no son TTY: texto sin formato.
  • --json: JSON delimitado por líneas (un evento de registro por línea).
  • --plain: fuerza texto sin formato en sesiones TTY.
  • --no-color: desactiva los colores ANSI.

Cuando pasa un --url explícito, la CLI no aplica automáticamente la configuración o las credenciales del entorno; incluya --token usted mismo si el Gateway de destino requiere autenticación.

En modo JSON, la CLI emite objetos etiquetados con type:

  • meta: metadatos de flujo (archivo, cursor, tamaño)
  • log: entrada de registro analizada
  • notice: sugerencias de truncamiento / rotación
  • raw: línea de registro no analizada

Si el Gateway de bucle local implícito solicita emparejamiento, se cierra durante la conexión, o expira antes de que logs.tail responda, openclaw logs recurre automáticamente al registro de archivos del Gateway configurado. Los destinos --url explícitos no utilizan este retorno.

Si el Gateway no está accesible, la CLI imprime un breve consejo para ejecutar:

Ventana de terminal
openclaw doctor

La pestaña Registros de la Interfaz de Control sigue el mismo archivo usando logs.tail. Consulte Interfaz de Control para saber cómo abrirla.

Para filtrar la actividad del canal (WhatsApp/Telegram/etc), use:

Ventana de terminal
openclaw channels logs --channel whatsapp

Cada línea en el archivo de registro es un objeto JSON. La CLI y la Interfaz de Control analizan estas entradas para generar una salida estructurada (hora, nivel, subsistema, mensaje).

Los registros JSONL de archivos también incluyen campos de nivel superior filtrables por máquina cuando están disponibles:

  • hostname: nombre del host del gateway.
  • message: texto de mensaje de registro aplanado para búsqueda de texto completo.
  • agent_id: id del agente activo cuando la llamada al registro lleva contexto del agente.
  • session_id: id/clave de sesión activa cuando la llamada al registro lleva contexto de sesión.
  • channel: canal activo cuando la llamada al registro lleva contexto de canal.

OpenClaw preserva los argumentos de registro estructurados originales junto con estos campos para que los analizadores existentes que leen claves de argumentos numeradas de tslog sigan funcionando.

La actividad de Talk, voz en tiempo real y salas administradas emite registros de ciclo de vida delimitados a través de esta misma canalización de registro de archivo. Estos registros incluyen tipo de evento, modo, transporte, proveedor y mediciones de tamaño/tiempo cuando están disponibles, pero omiten el texto de la transcripción, las cargas útiles de audio, los ids de turno, los ids de llamada y los ids de elementos del proveedor.

Los registros de la consola son conscientes de TTY y están formateados para facilitar la lectura:

  • Prefijos de subsistema (ej. gateway/channels/whatsapp)
  • Coloreado por nivel (información/advertencia/error)
  • Modo compacto o JSON opcional

El formato de la consola se controla mediante logging.consoleStyle.

openclaw gateway también tiene registro de protocolo WebSocket para el tráfico RPC:

  • modo normal: solo resultados interesantes (errores, errores de análisis, llamadas lentas)
  • --verbose: todo el tráfico de solicitud/respuesta
  • --ws-log auto|compact|full: elige el estilo de representación detallada
  • --compact: alias para --ws-log compact

Ejemplos:

Ventana de terminal
openclaw gateway
openclaw gateway --verbose --ws-log compact
openclaw gateway --verbose --ws-log full

Toda la configuración de registro se encuentra bajo logging en ~/.openclaw/openclaw.json.

{
"logging": {
"level": "info",
"file": "/tmp/openclaw/openclaw-YYYY-MM-DD.log",
"consoleLevel": "info",
"consoleStyle": "pretty",
"redactSensitive": "tools",
"redactPatterns": ["sk-.*"]
}
}
  • logging.level: nivel de registros de archivo (JSONL).
  • logging.consoleLevel: nivel de verbosidad de la consola.

Puedes anular ambos mediante la variable de entorno OPENCLAW_LOG_LEVEL (ej. OPENCLAW_LOG_LEVEL=debug). La variable de entorno tiene prioridad sobre el archivo de configuración, por lo que puedes aumentar la verbosidad para una sola ejecución sin editar openclaw.json. También puedes pasar la opción global de CLI --log-level <level> (por ejemplo, openclaw --log-level debug gateway run), que anula la variable de entorno para ese comando.

--verbose solo afecta la salida de la consola y la verbosidad del registro de WS; no cambia los niveles de registro de archivos.

Diagnósticos de transporte de modelo específicos

Sección titulada «Diagnósticos de transporte de modelo específicos»

Al depurar llamadas al proveedor, usa indicadores de entorno específicos en lugar de elevar todos los registros a debug:

Ventana de terminal
OPENCLAW_DEBUG_MODEL_TRANSPORT=1 openclaw gateway
OPENCLAW_DEBUG_MODEL_PAYLOAD=tools OPENCLAW_DEBUG_SSE=events openclaw gateway

Indicadores disponibles:

  • OPENCLAW_DEBUG_MODEL_TRANSPORT=1: emite el inicio de la solicitud, la respuesta de obtención, los encabezados del SDK, el primer evento de transmisión, la finalización de la transmisión y los errores de transporte en el nivel info.
  • OPENCLAW_DEBUG_MODEL_PAYLOAD=summary: incluye un resumen limitado de la carga útil de la solicitud en los registros de solicitudes del modelo.
  • OPENCLAW_DEBUG_MODEL_PAYLOAD=tools: incluye todos los nombres de herramientas orientadas al modelo en el resumen de la carga útil.
  • OPENCLAW_DEBUG_MODEL_PAYLOAD=full-redacted: incluye una instantánea de carga útil JSON redactada y limitada. Úselo solo durante la depuración; los secretos están redactados, pero los prompts y el texto del mensaje aún pueden estar presentes.
  • OPENCLAW_DEBUG_SSE=events: emite la sincronización del primer evento y la finalización del flujo.
  • OPENCLAW_DEBUG_SSE=peek: también emite las primeras cinco cargas útiles de eventos SSE redactadas, limitadas por evento.
  • OPENCLAW_DEBUG_CODE_MODE=1: emite diagnósticos de superficie del modelo en modo de código, incluyendo cuándo las herramientas nativas del proveedor están ocultas porque el modo de código posee la superficie de herramientas.

Estas banderas registran a través del registro normal de OpenClaw, por lo que openclaw logs --follow y la pestaña Logs del Control UI las muestran. Sin las banderas, los mismos diagnósticos siguen disponibles en el nivel debug.

Los registros de archivo son JSONL. Cuando una llamada de registro lleva un contexto de rastreo de diagnóstico válido, OpenClaw escribe los campos de rastreo como claves JSON de nivel superior (traceId, spanId, parentSpanId, traceFlags) para que los procesadores de registros externos puedan correlacionar la línea con los intervalos OTEL y la propagación del traceparent del proveedor.

Las solicitudes HTTP de Gateway y los marcos WebSocket de Gateway establecen un alcance de rastreo de solicitud interno. Los registros y eventos de diagnóstico emitidos dentro de ese alcance asíncrono heredan el rastreo de solicitud cuando no pasan un contexto de rastreo explícito. Los rastros de ejecución del agente y de llamadas al modelo se convierten en hijos del rastreo de solicitud activo, por lo que los registros locales, las instantáneas de diagnóstico, los intervalos OTEL y los encabezados traceparent de proveedores confiables pueden unirse mediante traceId sin registrar el contenido sin procesar de la solicitud o del modelo.

Los registros de ciclo de vida de conversación también fluyen hacia los registros OTLP cuando la exportación de registros de OpenTelemetry está habilitada, utilizando los mismos atributos limitados que los registros de archivo.

Tamaño y sincronización de la llamada al modelo

Sección titulada «Tamaño y sincronización de la llamada al modelo»

Los diagnósticos de llamadas al modelo registran mediciones de solicitud/respuesta limitadas sin capturar el contenido sin procesar del prompt o de la respuesta:

  • requestPayloadBytes: tamaño en bytes UTF-8 de la carga útil final de solicitud al modelo
  • responseStreamBytes: tamaño en bytes UTF-8 de los eventos de respuesta del modelo transmitidos en flujo
  • timeToFirstByteMs: tiempo transcurrido antes del primer evento de respuesta transmitida en flujo
  • durationMs: duración total de la llamada al modelo

Estos campos están disponibles para las instantáneas de diagnóstico, los enlaces (hooks) de complementos de llamadas al modelo y los intervalos (spans)/métricas de llamadas al modelo de OTEL cuando la exportación de diagnósticos está habilitada.

logging.consoleStyle:

  • pretty: amigable para humanos, coloreado, con marcas de tiempo.
  • compact: salida más compacta (ideal para sesiones largas).
  • json: JSON por línea (para procesadores de registros).

OpenClaw puede redactar tokens sensibles antes de que lleguen a la salida de la consola, los registros de archivos, los registros de logs de OTLP, el texto de la transcripción de la sesión persistida o las cargas útiles de eventos de herramientas de la UI de Control (argumentos de inicio de herramienta, cargas útiles de resultados parciales/finales, salida exec derivada y resúmenes de parches):

  • logging.redactSensitive: off | tools (predeterminado: tools)
  • logging.redactPatterns: lista de cadenas de regex para anular el conjunto predeterminado. Los patrones personalizados se aplican además de los valores predeterminados integrados para las cargas útiles de herramientas de la UI de Control, por lo que agregar un patrón nunca debilita la redacción de valores ya capturados por los predeterminados.

Los registros de archivos y las transcripciones de sesión se mantienen en JSONL, pero los valores secretos coincidentes se enmascaran antes de que la línea o el mensaje se escriba en el disco. La redacción es de mejor esfuerzo: se aplica al contenido de mensajes que lleva texto y cadenas de registro, no a todos los identificadores o campos de carga útil binaria.

Los valores predeterminados integrados cubren nombres de campos de credenciales de API comunes y de credenciales de pago, como el número de tarjeta, CVC/CVV, token de pago compartido y credencial de pago cuando aparecen como campos JSON, parámetros de URL, indicadores de CLI o asignaciones.

logging.redactSensitive: "off" solo deshabilita esta política general de registro/transcripción. OpenClaw todavía redacta las cargas útiles de límites de seguridad que se pueden mostrar a los clientes de la UI, paquetes de soporte, observadores de diagnóstico, indicadores de aprobación o herramientas de agente. Los ejemplos incluyen eventos de llamadas a herramientas de la UI de Control, la salida de sessions_history, exportaciones de soporte de diagnóstico, observaciones de errores de proveedores, visualización de comandos de aprobación de exec y registros de protocolo WebSocket de Gateway. Los patrones logging.redactPatterns personalizados aún pueden agregar patrones específicos del proyecto en esas superficies.

Los diagnósticos son eventos estructurados y legibles por máquina para ejecuciones de modelos y telemetría de flujo de mensajes (webhooks, colas, estado de la sesión). No reemplazan los registros; alimentan métricas, trazas y exportadores. Los eventos se emiten en proceso, independientemente de si los exporta o no.

Dos superficies adyacentes:

  • Exportación de OpenTelemetry — envía métricas, trazas y registros a través de OTLP/HTTP a cualquier recopilador o backend compatible con OpenTelemetry (Grafana, Datadog, Honeycomb, New Relic, Tempo, etc.). La configuración completa, el catálogo de señales, los nombres de métricas/tramos, las variables de entorno y el modelo de privacidad se encuentran en una página dedicada: Exportación de OpenTelemetry.
  • Marcadores de diagnóstico — marcadores de registro de depuración específicos que enrutan registros adicionales a logging.file sin elevar logging.level. Los marcadores no distinguen entre mayúsculas y minúsculas y admiten comodines (telegram.*, *). Configure en diagnostics.flags o a través de la anulación de la variable de entorno OPENCLAW_DIAGNOSTICS=.... Guía completa: Marcadores de diagnóstico.

Para habilitar eventos de diagnóstico para complementos o sumideros personalizados sin exportación OTLP:

{
diagnostics: { enabled: true },
}

Para la exportación OTLP a un recopilador, consulte Exportación de OpenTelemetry.

  • ¿No se puede alcanzar la puerta de enlace? Ejecute primero openclaw doctor.
  • ¿Registros vacíos? Verifique que la puerta de enlace se esté ejecutando y escribiendo en la ruta del archivo en logging.file.
  • ¿Necesita más detalles? Establezca logging.level en debug o trace e inténtelo de nuevo.