Elk model heeft een contextvenster: het maximale aantal tokens dat het kan verwerken. Wanneer een gesprek die limiet nadert, compacteert OpenClaw oudere berichten tot een samenvatting zodat de chat kan doorgaan.Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Hoe het werkt
- Oudere gespreksrondes worden samengevat tot een compacte invoer.
- De samenvatting wordt opgeslagen in het sessietranscript.
- Recente berichten blijven intact.
toolResult-items. Als een splitspunt binnen een toolblok valt, verplaatst OpenClaw de grens zodat het paar bij elkaar blijft en de huidige niet-samengevatte staart behouden blijft.
De volledige gespreksgeschiedenis blijft op schijf staan. Compaction verandert alleen wat het model bij de volgende beurt ziet.
Auto-compaction
Auto-compaction is standaard ingeschakeld. Dit wordt uitgevoerd wanneer de sessie de contextlimiet nadert, of wanneer het model een context-overflowfout retourneert (in dat geval compacteert OpenClaw en probeert het opnieuw). Je ziet:🧹 Auto-compaction completein uitgebreide modus./statustoont🧹 Compactions: <count>.
Voordat er wordt gecompacteerd, herinnert OpenClaw de agent er automatisch aan om belangrijke notities op te slaan in geheugen-bestanden. Dit voorkomt contextverlies.
Herkende overflowhandtekeningen
Herkende overflowhandtekeningen
OpenClaw detecteert context-overflow aan de hand van deze foutpatronen van providers:
request_too_largecontext length exceededinput exceeds the maximum number of tokensinput token count exceeds the maximum number of input tokensinput is too long for the modelollama error: context length exceeded
Handmatige Compaction
Typ/compact in een chat om Compaction te forceren. Voeg instructies toe om de samenvatting te sturen:
agents.defaults.compaction.keepRecentTokens is ingesteld, respecteert handmatige Compaction dat Pi-snijpunt en behoudt het de recente staart in de opnieuw opgebouwde context. Zonder een expliciet behoudsbudget gedraagt handmatige Compaction zich als een harde checkpoint en gaat verder vanaf alleen de nieuwe samenvatting.
Configuratie
Configureer Compaction onderagents.defaults.compaction in je openclaw.json. De meestgebruikte knoppen staan hieronder; zie diepgaande uitleg over sessiebeheer voor de volledige referentie.
Een ander model gebruiken
Standaard gebruikt Compaction het primaire model van de agent. Stelagents.defaults.compaction.model in om samenvatting uit te besteden aan een capabeler of gespecialiseerder model. De overschrijving accepteert elke provider/model-id-tekenreeks:
agents.defaults.compaction.model blijft exact en erft de sessie-fallbackketen niet.
Behoud van identifiers
Compaction-samenvatting behoudt standaard ondoorzichtige identifiers (identifierPolicy: "strict"). Overschrijf met identifierPolicy: "off" om dit uit te schakelen, of met identifierPolicy: "custom" plus identifierInstructions voor aangepaste richtlijnen.
Bytebewaking voor actief transcript
Wanneeragents.defaults.compaction.maxActiveTranscriptBytes is ingesteld, activeert OpenClaw normale lokale Compaction vóór een run als de actieve JSONL die grootte bereikt. Dit is nuttig voor langlopende sessies waarbij contextbeheer aan providerzijde de modelcontext gezond kan houden terwijl het lokale transcript blijft groeien. Het splitst geen ruwe JSONL-bytes; het vraagt de normale Compaction-pijplijn om een semantische samenvatting te maken.
Opvolgende transcripties
Wanneeragents.defaults.compaction.truncateAfterCompaction is ingeschakeld, herschrijft OpenClaw het bestaande transcript niet op zijn plek. Het maakt een nieuw actief opvolgend transcript op basis van de Compaction-samenvatting, behouden status en niet-samengevatte staart, en behoudt vervolgens de vorige JSONL als de gearchiveerde checkpointbron.
Opvolgende transcripties verwijderen ook exacte dubbele lange gebruikersbeurten die binnen een kort retryvenster binnenkomen, zodat kanaal-retrystormen niet worden meegenomen naar het volgende actieve transcript na Compaction.
Pre-Compaction-checkpoints worden alleen bewaard zolang ze onder de checkpointgroottelimiet van OpenClaw blijven; te grote actieve transcripties worden nog steeds gecompacteerd, maar OpenClaw slaat de grote debugsnapshot over in plaats van het schijfgebruik te verdubbelen.
Compaction-meldingen
Standaard draait Compaction stil. StelnotifyUser in om korte statusberichten te tonen wanneer Compaction start en wordt voltooid:
Geheugenflush
Voor Compaction kan OpenClaw een stille geheugenflush-beurt uitvoeren om duurzame notities op schijf op te slaan. Stelagents.defaults.compaction.memoryFlush.model in wanneer deze onderhoudsbeurt een lokaal model moet gebruiken in plaats van het actieve gespreksmodel:
Inplugbare Compaction-providers
Plugins kunnen een aangepaste Compaction-provider registreren viaregisterCompactionProvider() op de Plugin-API. Wanneer een provider is geregistreerd en geconfigureerd, besteedt OpenClaw samenvatting daaraan uit in plaats van aan de ingebouwde LLM-pijplijn.
Stel de id in je configuratie in om een geregistreerde provider te gebruiken:
provider forceert automatisch mode: "safeguard". Providers ontvangen dezelfde Compaction-instructies en hetzelfde beleid voor identifierbehoud als het ingebouwde pad, en OpenClaw behoudt nog steeds recente-beurt- en split-beurt-achtervoegselcontext na provideruitvoer.
Als de provider faalt of een leeg resultaat retourneert, valt OpenClaw terug op ingebouwde LLM-samenvatting.
Compaction versus pruning
| Compaction | Pruning | |
|---|---|---|
| Wat het doet | Vat oudere conversatie samen | Kort oude toolresultaten in |
| Opgeslagen? | Ja (in sessietranscript) | Nee (alleen in geheugen, per verzoek) |
| Bereik | Volledige conversatie | Alleen toolresultaten |
Probleemoplossing
Te vaak compacten? Het contextvenster van het model is mogelijk klein, of tooluitvoer is mogelijk groot. Probeer sessiepruning in te schakelen. Context voelt verouderd na Compaction? Gebruik/compact Focus on <topic> om de samenvatting te sturen, of schakel de geheugenflush in zodat notities behouden blijven.
Een schone lei nodig? /new start een nieuwe sessie zonder te compacten.
Zie de diepgaande uitleg over sessiebeheer voor geavanceerde configuratie (gereserveerde tokens, identifierbehoud, aangepaste context-engines, server-side Compaction van OpenAI).
Gerelateerd
- Sessie: sessiebeheer en levenscyclus.
- Sessiepruning: toolresultaten inkorten.
- Context: hoe context wordt opgebouwd voor agentbeurten.
- Hooks: Compaction-levenscyclushooks (
before_compaction,after_compaction).