Fundamentals
Motor de contexto
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 motor 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
Comprueba qué motor está activo
openclaw doctor
# or inspect config directly:
cat ~/.openclaw/openclaw.json | jq '.plugins.slots.contextEngine'
Instala un motor de Plugin
Los Plugins de motor de contexto se instalan como cualquier otro Plugin de OpenClaw.
Desde npm
openclaw plugins install @martian-engineering/lossless-claw
Desde una ruta local
openclaw plugins install -l ./my-context-engine
Activa y selecciona el motor
// openclaw.json
{
plugins: {
slots: {
contextEngine: "lossless-claw", // must match the plugin's registered engine id
},
entries: {
"lossless-claw": {
enabled: true,
// Plugin-specific config goes here (see the plugin's docs)
},
},
},
}
Reinicia el Gateway después de instalar y configurar.
Vuelve a legacy (opcional)
Define contextEngine como "legacy" (o elimina la clave por completo; "legacy" es el valor predeterminado).
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
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
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
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
Se llama después de que finaliza una ejecución. El motor puede persistir estado, activar Compaction en segundo plano o actualizar índices.
Para el arnés Codex no ACP incluido, OpenClaw aplica el mismo ciclo de vida proyectando el contexto ensamblado en las instrucciones de desarrollador de Codex y en el prompt del turno actual. Codex sigue siendo propietario de su historial de hilos nativo y de su compactador nativo.
Ciclo de vida de subagentes (opcional)
OpenClaw llama a dos hooks opcionales del ciclo de vida de subagentes:
prepareSubagentSpawnmethodPrepara 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.
onSubagentEndedmethodLimpia cuando una sesión de subagente se completa o se barre.
Adición al prompt del sistema
El método assemble 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 motor legacy 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.
El motor legacy no registra herramientas ni proporciona un 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:
export default function register(api) {
api.registerContextEngine("my-engine", (ctx) => ({
info: {
id: "my-engine",
name: "My Context Engine",
ownsCompaction: true,
},
async ingest({ sessionId, message, isHeartbeat }) {
// Store the message in your data store
return { ingested: true };
},
async assemble({ sessionId, messages, tokenBudget, availableTools, citationsMode }) {
// Return messages that fit the budget
return {
messages: buildContext(messages, tokenBudget),
estimatedTokens: countTokens(messages),
systemPromptAddition: buildMemorySystemPromptAddition({
availableTools: availableTools ?? new Set(),
citationsMode,
}),
};
},
async compact({ sessionId, force }) {
// Summarize older context
return { ok: true, compacted: true };
},
}));
}
La fábrica 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:
{
plugins: {
slots: {
contextEngine: "my-engine",
},
entries: {
"my-engine": {
enabled: true,
},
},
},
}
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:
messagesMessage[]requiredLos mensajes ordenados que se envían al modelo.
estimatedTokensnumberrequiredLa 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.
systemPromptAdditionstringSe antepone al prompt del sistema.
promptAuthority"assembled" | "preassembly_may_overflow"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
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
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.
Eso significa que hay dos patrones válidos de Plugin:
Modo propietario
Implementa tu propio algoritmo de Compaction y define ownsCompaction: true.
Modo delegado
Define ownsCompaction: false y haz que compact() llame a delegateCompactionToRuntime(...) desde openclaw/plugin-sdk/core para usar el comportamiento de Compaction integrado de OpenClaw.
Un 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
{
plugins: {
slots: {
// Select the active context engine. Default: "legacy".
// Set to a plugin id to use a plugin engine.
contextEngine: "legacy",
},
},
}
Relación con Compaction y memoria
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
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
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