Install
openclaw skills install context-compressionPrevent context overflow with automatic session truncation and memory preservation.
openclaw skills install context-compressionKeep conversations within limits. Never lose important context.
⚡ After installing, run the interactive setup wizard to generate your config file, then add the suggested cron entry with
crontab -e. See Quick Start below for commands.
File location: ClawHub installs this skill to
~/.openclaw/workspace/skills/context-compression/. All scripts are placed here directly. This is the standard OpenClaw skill install path — no manual file placement needed.
# 1. Install and configure (interactive)
bash ~/.openclaw/workspace/skills/context-compression/configure.sh
# 2. Verify config exists
cat ~/.openclaw/workspace/.context-compression-config.json
# 3. Set up crontab (example: every 10 minutes)
*/10 * * * * ~/.openclaw/workspace/skills/context-compression/truncate-sessions-safe.sh
truncate-sessions-safe.sh)*/10 * * * *).jsonl session files under ~/.openclaw/agents/*/sessions/, trims each file to the configured size.lock file (active session)priority-first scans for important keywords before trimming and preserves matching linesidentify-facts.sh — scans truncated content for keywords (重要, 决定, TODO, 偏好, deadline, must remember, etc.) and appends findings to memory/YYYY-MM-DD.mdidentify-facts-enhanced.sh — calls openclaw agent --agent main --message with the trimmed content to semantically identify important facts. Only used when openclaw CLI is available on PATH.truncate-sessions-safe.sh calls one of these before each truncation cyclecheck-preferences-expiry.sh)@YYYY-MM-DD, removes expired ones| Script | Purpose | Scheduling |
|---|---|---|
truncate-sessions-safe.sh | Trim session JSONL files | crontab, every 10 min |
identify-facts.sh | Keyword-based fact detection | Called by truncate script |
identify-facts-enhanced.sh | AI-assisted fact detection | Called by truncate script |
check-preferences-expiry.sh | Remove expired preferences | crontab, once daily |
configure.sh | Interactive setup wizard | Manual, one-time |
session-start-hook.sh | Load context at session start | Called by AGENTS.md |
session-end-hook.sh | Save context at session end | Called by AGENTS.md |
check-context-health.sh | Report current context status | Manual / on-demand |
File: ~/.openclaw/workspace/.context-compression-config.json
{
"version": "2.3",
"maxChars": 40000,
"frequencyMinutes": 10,
"skipActive": true,
"strategy": "priority-first",
"useAiIdentification": false,
"priorityKeywords": [
"重要", "决定", "记住", "TODO", "偏好",
"important", "remember", "must", "deadline"
]
}
| Field | Type | Default | Description |
|---|---|---|---|
| maxChars | number | 40000 | Max chars to keep per session file |
| frequencyMinutes | number | 10 | How often crontab runs truncate |
| skipActive | boolean | true | Skip sessions with .lock files |
| strategy | string | priority-first | Truncation strategy |
| useAiIdentification | boolean | false | Set true to use AI-assisted fact identification (may send content to remote LLMs) |
| priorityKeywords | string[] | (see above) | Keywords to preserve during truncation |
| Problem | Solution |
|---|---|
| Context still exceeded | Reduce maxChars in config |
| Memory not persisting | Check that AGENTS.md includes session-start-hook |
| Crontab not running | Verify PATH in crontab includes node/openclaw binary location |
truncate-sessions-safe.sh creates a .pre-trim backup of each file before modification. Backups are cleaned up after a successful write..lock (currently in use) are always skipped, even if oversized.All configuration values have conservative defaults:
skipActive: true — never touches a running sessionmaxChars: 40000 — keeps substantial history per sessionstrategy: priority-first — preserves lines matching priority keywords before trimming anythingopenclaw CLI — network activity depends on your OpenClaw configuration.configure.sh wizard runs interactively and requires user input.~/.openclaw/agents/main/ and ~/.openclaw/workspace/memory/. Never touches system files, other agents' data, or other users' data.identify-facts-enhanced.sh) is disabled by default. It invokes the local openclaw agent CLI, which may send session content to remote LLM services depending on your OpenClaw configuration. Only enable it if you understand and accept this data flow. To enable, set "useAiIdentification": true in the config file.identify-facts.sh) is the default and runs entirely locally with no external data transmission.