--- summary: "How OpenClaw summarizes long conversations to stay within model limits" read_when: - You want to understand auto-compaction and /compact - You are debugging long sessions hitting context limits title: "Compaction" --- # Compaction Every model has a context window -- the maximum number of tokens it can process. When a conversation approaches that limit, OpenClaw **compacts** older messages into a summary so the chat can continue. ## How it works 1. Older conversation turns are summarized into a compact entry. 2. The summary is saved in the session transcript. 3. Recent messages are kept intact. The full conversation history stays on disk. Compaction only changes what the model sees on the next turn. ## Auto-compaction Auto-compaction is on by default. It runs when the session nears the context limit, or when the model returns a context-overflow error (in which case OpenClaw compacts and retries). Before compacting, OpenClaw automatically reminds the agent to save important notes to [memory](/concepts/memory) files. This prevents context loss. ## Manual compaction Type `/compact` in any chat to force a compaction. Add instructions to guide the summary: ``` /compact Focus on the API design decisions ``` ## Using a different model By default, compaction uses your agent's primary model. You can use a more capable model for better summaries: ```json5 { agents: { defaults: { compaction: { model: "openrouter/anthropic/claude-sonnet-4-6", }, }, }, } ``` ## Compaction vs pruning | | Compaction | Pruning | | ---------------- | ----------------------------- | -------------------------------- | | **What it does** | Summarizes older conversation | Trims old tool results | | **Saved?** | Yes (in session transcript) | No (in-memory only, per request) | | **Scope** | Entire conversation | Tool results only | [Session pruning](/concepts/session-pruning) is a lighter-weight complement that trims tool output without summarizing. ## Troubleshooting **Compacting too often?** The model's context window may be small, or tool outputs may be large. Try enabling [session pruning](/concepts/session-pruning). **Context feels stale after compaction?** Use `/compact Focus on ` to guide the summary, or enable the [memory flush](/concepts/memory) so notes survive. **Need a clean slate?** `/new` starts a fresh session without compacting. For advanced configuration (reserve tokens, identifier preservation, custom context engines, OpenAI server-side compaction), see the [Session Management Deep Dive](/reference/session-management-compaction).