Un motor de contexto controla cómo OpenClaw construye el contexto del modelo para cada ejecución: qué mensajes incluir, cómo resumir el historial antiguo y cómo gestionar el contexto a través de los límites de subagentes. OpenClaw incluye un motorDocumentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
legacy integrado y lo usa de forma predeterminada; la mayoría de los usuarios nunca necesitan cambiarlo. Instala y selecciona un motor de Plugin solo cuando quieras un comportamiento distinto de ensamblaje, Compaction o recuperación entre sesiones.
Inicio rápido
Instala un motor de Plugin
Los Plugins de motor de contexto se instalan como cualquier otro Plugin de OpenClaw.
- Desde npm
- Desde una ruta local
Cómo funciona
Cada vez que OpenClaw ejecuta un prompt de modelo, el motor de contexto participa en cuatro puntos del ciclo de vida:1. Ingesta
1. Ingesta
Se llama cuando se agrega un nuevo mensaje a la sesión. El motor puede almacenar o indexar el mensaje en su propio almacén de datos.
2. Ensamblaje
2. Ensamblaje
Se llama antes de cada ejecución del modelo. El motor devuelve un conjunto ordenado de mensajes (y un
systemPromptAddition opcional) que cabe dentro del presupuesto de tokens.3. Compact
3. Compact
Se llama cuando la ventana de contexto está llena o cuando el usuario ejecuta
/compact. El motor resume el historial antiguo para liberar espacio.4. Después del turno
4. Después del turno
Se llama después de que finaliza una ejecución. El motor puede persistir estado, activar Compaction en segundo plano o actualizar índices.
Ciclo de vida de subagentes (opcional)
OpenClaw llama a dos hooks opcionales del ciclo de vida de subagentes:Prepara el estado de contexto compartido antes de que comience una ejecución hija. El hook recibe claves de sesión padre/hija,
contextMode (isolated o fork), ids/archivos de transcripción disponibles y TTL opcional. Si devuelve un identificador de reversión, OpenClaw lo llama cuando la generación falla después de que la preparación se completa correctamente.Limpia cuando una sesión de subagente se completa o se barre.
Adición al prompt del sistema
El métodoassemble puede devolver una cadena systemPromptAddition. OpenClaw la antepone al prompt del sistema para la ejecución. Esto permite que los motores inyecten orientación dinámica de recuperación, instrucciones de recuperación o sugerencias sensibles al contexto sin requerir archivos estáticos del espacio de trabajo.
El motor legacy
El motorlegacy integrado conserva el comportamiento original de OpenClaw:
- Ingesta: sin operación (el gestor de sesiones maneja directamente la persistencia de mensajes).
- Ensamblaje: paso directo (la canalización existente sanitize → validate → limit en el runtime maneja el ensamblaje de contexto).
- Compact: delega en la Compaction de resumen integrada, que crea un único resumen de los mensajes antiguos y mantiene intactos los mensajes recientes.
- Después del turno: sin operación.
systemPromptAddition.
Cuando no se define plugins.slots.contextEngine (o se define como "legacy"), este motor se usa automáticamente.
Motores de Plugin
Un Plugin puede registrar un motor de contexto mediante la API de Plugin:ctx incluye valores opcionales config, agentDir y workspaceDir
para que los Plugins puedan inicializar estado por agente o por espacio de trabajo antes de que se ejecute el
primer hook de ciclo de vida.
Luego actívalo en la configuración:
La interfaz ContextEngine
Miembros obligatorios:| Miembro | Tipo | Propósito |
|---|---|---|
info | Propiedad | Id, nombre, versión del motor y si posee la Compaction |
ingest(params) | Método | Almacenar un único mensaje |
assemble(params) | Método | Construir contexto para una ejecución de modelo (devuelve AssembleResult) |
compact(params) | Método | Resumir/reducir contexto |
assemble devuelve un AssembleResult con:
Los mensajes ordenados que se envían al modelo.
La estimación del motor del total de tokens en el contexto ensamblado. OpenClaw usa esto para decisiones de umbral de Compaction e informes de diagnóstico.
Se antepone al prompt del sistema.
Controla qué estimación de tokens usa el ejecutor para las comprobaciones previas preventivas de desbordamiento. El valor predeterminado es
"assembled", lo que significa que solo se comprueba la estimación del prompt ensamblado; es apropiado para motores que devuelven un contexto con ventana y autónomo. Defínelo como "preassembly_may_overflow" solo cuando tu vista ensamblada pueda ocultar el riesgo de desbordamiento en la transcripción subyacente; entonces el ejecutor toma el máximo entre la estimación ensamblada y la estimación del historial de sesión previo al ensamblaje (sin ventana) al decidir si debe hacer Compaction preventivamente. En cualquier caso, los mensajes que devuelves siguen siendo lo que ve el modelo; promptAuthority solo afecta la comprobación previa.compact devuelve un CompactResult. Cuando la Compaction rota la transcripción activa, result.sessionId y result.sessionFile identifican la sesión sucesora que debe usar el siguiente reintento o turno.
Miembros opcionales:
| Miembro | Tipo | Propósito |
|---|---|---|
bootstrap(params) | Método | Inicializar el estado del motor para una sesión. Se llama una vez cuando el motor ve una sesión por primera vez (por ejemplo, importar historial). |
ingestBatch(params) | Método | Ingerir un turno completado como lote. Se llama después de que finaliza una ejecución, con todos los mensajes de ese turno a la vez. |
afterTurn(params) | Método | Trabajo de ciclo de vida posterior a la ejecución (persistir estado, activar Compaction en segundo plano). |
prepareSubagentSpawn(params) | Método | Configurar estado compartido para una sesión hija antes de que comience. |
onSubagentEnded(params) | Método | Limpiar después de que finaliza un subagente. |
dispose() | Método | Liberar recursos. Se llama durante el apagado del Gateway o la recarga del Plugin, no por sesión. |
ownsCompaction
ownsCompaction controla si la Compaction automática en intento integrada de Pi permanece activada para la ejecución:
ownsCompaction: true
ownsCompaction: true
El motor posee el comportamiento de Compaction. OpenClaw desactiva la Compaction automática integrada de Pi para esa ejecución, y la implementación
compact() del motor es responsable de /compact, la Compaction de recuperación de desbordamiento y cualquier Compaction proactiva que quiera hacer en afterTurn(). OpenClaw aún puede ejecutar la protección contra desbordamiento previa al prompt; cuando predice que la transcripción completa se desbordará, la ruta de recuperación llama a compact() del motor activo antes de enviar otro prompt.ownsCompaction: false o sin definir
ownsCompaction: false o sin definir
La Compaction automática integrada de Pi aún puede ejecutarse durante la ejecución del prompt, pero el método
compact() del motor activo se sigue llamando para /compact y la recuperación de desbordamiento.- Modo propietario
- Modo delegado
Implementa tu propio algoritmo de Compaction y define
ownsCompaction: true.compact() sin operación no es seguro para un motor activo que no posee Compaction porque desactiva la ruta normal de Compaction de /compact y recuperación de desbordamiento para ese slot de motor.
Referencia de configuración
El slot es exclusivo en tiempo de ejecución: solo se resuelve un motor de contexto registrado para una ejecución u operación de Compaction determinada. Otros Plugins
kind: "context-engine" activados aún pueden cargarse y ejecutar su código de registro; plugins.slots.contextEngine solo selecciona qué id de motor registrado resuelve OpenClaw cuando necesita un motor de contexto.Desinstalación de Plugin: cuando desinstalas el Plugin seleccionado actualmente como
plugins.slots.contextEngine, OpenClaw restablece el slot al valor predeterminado (legacy). El mismo comportamiento de restablecimiento se aplica a plugins.slots.memory. No se requiere ninguna edición manual de la configuración.Relación con Compaction y memoria
Compaction
Compaction
Compaction es una responsabilidad del motor de contexto. El motor heredado delega en la resumición integrada de OpenClaw. Los motores de Plugin pueden implementar cualquier estrategia de compaction (resúmenes DAG, recuperación vectorial, etc.).
Plugins de memoria
Plugins de memoria
Los plugins de memoria (
plugins.slots.memory) están separados de los motores de contexto. Los plugins de memoria proporcionan búsqueda/recuperación; los motores de contexto controlan lo que ve el modelo. Pueden trabajar juntos: un motor de contexto podría usar datos de plugins de memoria durante el ensamblaje. Los motores de Plugin que quieran la ruta de prompt de active memory deberían preferir buildMemorySystemPromptAddition(...) de openclaw/plugin-sdk/core, que convierte las secciones del prompt de active memory en un systemPromptAddition listo para anteponer. Si un motor necesita control de menor nivel, aún puede extraer líneas sin procesar de openclaw/plugin-sdk/memory-host-core mediante buildActiveMemoryPromptSection(...).Poda de sesiones
Poda de sesiones
El recorte de resultados antiguos de herramientas en memoria sigue ejecutándose independientemente de qué motor de contexto esté activo.
Consejos
- Usa
openclaw doctorpara verificar que tu motor se esté cargando correctamente. - Si cambias de motor, las sesiones existentes continúan con su historial actual. El nuevo motor toma el control para ejecuciones futuras.
- Los errores del motor se registran y se muestran en diagnósticos. Si un motor de plugin no logra registrarse o el id del motor seleccionado no se puede resolver, OpenClaw no vuelve atrás automáticamente; las ejecuciones fallan hasta que corrijas el plugin o cambies
plugins.slots.contextEnginede nuevo a"legacy". - Para desarrollo, usa
openclaw plugins install -l ./my-enginepara enlazar un directorio local de plugin sin copiarlo.
Relacionado
- Compaction - resumir conversaciones largas
- Contexto - cómo se construye el contexto para los turnos del agente
- Arquitectura de Plugin - registrar plugins de motor de contexto
- Manifiesto de Plugin - campos del manifiesto de plugin
- Plugins - descripción general de plugins