Community translations by veiseule.ai — Help improve them on Crowdin
Skip to main content

Session Management & Compaction (နက်ရှိုင်းစွာရှင်းလင်းချက်)

ဤစာရွက်စာတမ်းသည် OpenClaw က session များကို အဆုံးမှအဆုံး ဘယ်လို စီမံခန့်ခွဲသလဲကို ရှင်းပြထားသည် —

  • Session routing (ဝင်လာသော မက်ဆေ့ချ်များကို sessionKey သို့ မည်သို့ မြေပုံချသတ်မှတ်သလဲ)
  • Session store (sessions.json) နှင့် ၎င်းတွင် မည်သည့်အရာများကို ခြေရာခံထားသည်
  • Transcript persistence (*.jsonl) နှင့် ၎င်း၏ ဖွဲ့စည်းပုံ
  • Transcript hygiene (run မလုပ်မီ provider အလိုက် ပြုပြင်ညှိနှိုင်းမှုများ)
  • Context limits (context window နှင့် tracked tokens တို့၏ ကွာခြားချက်)
  • Compaction (manual + auto-compaction) နှင့် pre-compaction အလုပ်များကို ချိတ်ဆက်သင့်သည့် နေရာ
  • Silent housekeeping (ဥပမာ—အသုံးပြုသူမြင်နိုင်သော output မထုတ်သင့်သော memory write များ)

အရင်ဆုံး အမြင့်အဆင့်အမြင်တစ်ခုလိုပါက အောက်ပါတို့မှ စတင်ဖတ်ရှုနိုင်သည် —


Source of truth: Gateway

OpenClaw ကို session state ကို ကိုင်တွယ်ပိုင်ဆိုင်သော Gateway process တစ်ခုတည်း ကို အခြေခံအုတ်မြစ်အဖြစ် ဒီဇိုင်းလုပ်ထားသည်။

  • UI များ (macOS app, web Control UI, TUI) သည် session စာရင်းများနှင့် token အရေအတွက်များကို Gateway မှ မေးမြန်းသင့်သည်။
  • Remote mode တွင် session ဖိုင်များသည် remote host ပေါ်တွင် ရှိသည်။ “သင့် local Mac ဖိုင်များကို စစ်ဆေးခြင်း” သည် Gateway အသုံးပြုနေသည့် အရာများကို မပြသပါ။

Persistence အလွှာ နှစ်ခု

OpenClaw သည် session များကို အလွှာ နှစ်ခုဖြင့် သိမ်းဆည်းထားသည် —

  1. Session သိမ်းဆည်းမှု (sessions.json) - Key/value မက်ပ်: sessionKey -> SessionEntry - သေးငယ်ပြီး ပြောင်းလဲနိုင်ကာ ပြင်ဆင်ရန် (သို့မဟုတ် entry များကို ဖျက်ရန်) လုံခြုံသည် - Session metadata များ (လက်ရှိ session id, နောက်ဆုံး လှုပ်ရှားချိန်, toggles, token counters စသည်) ကို ခြေရာခံထားသည်

  2. Transcript မှတ်တမ်း (<sessionId>.jsonl) - Tree ဖွဲ့စည်းပုံပါသော append-only transcript (entries များတွင် id + parentId ပါရှိ) - စကားပြောဆိုမှု အမှန်တကယ်၊ tool calls နှင့် compaction summaries များကို သိမ်းဆည်းထားသည် - နောက်လာမည့် turn များအတွက် model context ကို ပြန်တည်ဆောက်ရန် အသုံးပြုသည်


Disk ပေါ်ရှိ နေရာများ

Gateway ဟို့စ်ပေါ်တွင် အေးဂျင့်တစ်ခုချင်းစီအလိုက် —

  • Store: ~/.openclaw/agents/<agentId>/sessions/sessions.json
  • Transcripts: ~/.openclaw/agents/<agentId>/sessions/<sessionId>.jsonl
  • Telegram topic sessions: .../<sessionId>-topic-<threadId>.jsonl

OpenClaw သည် src/config/sessions.ts မှတစ်ဆင့် ဤနေရာများကို ဖြေရှင်းသတ်မှတ်သည်။


Session keys (sessionKey)

sessionKey သည် သင်ရောက်ရှိနေသော စကားပြောဆိုမှု အုပ်စု ကို ခွဲခြားသတ်မှတ်ပေးသည် (routing + isolation)။

အများအားဖြင့် တွေ့ရသော ပုံစံများ —

  • Main/direct chat (အေးဂျင့်တစ်ခုချင်းစီ): agent:<agentId>:<mainKey> (မူလသတ်မှတ်ချက် main)
  • Group: agent:<agentId>:<channel>:group:<id>
  • Room/channel (Discord/Slack): agent:<agentId>:<channel>:channel:<id> သို့မဟုတ် ...:room:<id>
  • Cron: cron:<job.id>
  • Webhook: hook:<uuid> (override မလုပ်ထားလျှင်)

Canonical စည်းမျဉ်းများကို /concepts/session တွင် မှတ်တမ်းတင်ထားသည်။


Session ids (sessionId)

sessionKey တစ်ခုစီသည် လက်ရှိ sessionId (စကားပြောကို ဆက်လက်ရေးသားနေသော transcript ဖိုင်) ကို ညွှန်ပြထားသည်။

အတွေ့အကြုံအရ သတိပြုရန် —

  • Reset (/new, /reset) လုပ်ပါက ထို sessionKey အတွက် sessionId အသစ်တစ်ခု ဖန်တီးသည်။
  • Daily reset (Gateway ဟို့စ်၏ local time အရ မနက် 4:00 AM မူလသတ်မှတ်ချက်) သည် reset boundary ကျော်ပြီးနောက် ပထမဆုံး မက်ဆေ့ချ်တွင် sessionId အသစ်တစ်ခု ဖန်တီးသည်။
  • Idle expiry (session.reset.idleMinutes သို့မဟုတ် legacy session.idleMinutes) သည် idle window ကျော်လွန်ပြီးနောက် message တစ်ခု ရောက်လာသောအခါ sessionId အသစ်ကို ဖန်တီးပါသည်။ daily + idle နှစ်ခုစလုံးကို configure လုပ်ထားပါက အရင်ဆုံး expire ဖြစ်သည့် အရာက အနိုင်ရပါသည်။

Implementation အသေးစိတ် — ဆုံးဖြတ်ချက်သည် src/auto-reply/reply/session.ts ထဲရှိ initSessionState() တွင် ဖြစ်ပေါ်သည်။


Session store schema (sessions.json)

Store ၏ value type သည် src/config/sessions.ts ထဲရှိ SessionEntry ဖြစ်သည်။

အရေးကြီးသော fields များ (အပြည့်အစုံ မဟုတ်) —

  • sessionId: လက်ရှိ transcript id ( sessionFile မသတ်မှတ်ထားပါက filename ကို ဤအချက်မှ ဆင်းသက်ထုတ်ယူသည်)
  • updatedAt: နောက်ဆုံး လှုပ်ရှားချိန် timestamp
  • sessionFile: optional explicit transcript path override
  • chatType: direct | group | room (UI များနှင့် send policy ကို ကူညီသည်)
  • provider, subject, room, space, displayName: group/channel labeling အတွက် metadata
  • Toggles:
  • thinkingLevel, verboseLevel, reasoningLevel, elevatedLevel
  • sendPolicy (session တစ်ခုချင်းစီအလိုက် override)
  • Model ရွေးချယ်မှု:
  • providerOverride, modelOverride, authProfileOverride
  • Token counters (အကောင်းဆုံး ကြိုးပမ်းချက် / provider အလိုက် ကွာခြားနိုင်):
  • inputTokens, outputTokens, totalTokens, contextTokens
  • compactionCount: ဤ session key အတွက် auto-compaction ပြီးစီးခဲ့သည့် အကြိမ်ရေ
  • memoryFlushAt: နောက်ဆုံး pre-compaction memory flush ပြုလုပ်ခဲ့သည့် timestamp
  • memoryFlushCompactionCount: နောက်ဆုံး flush ပြုလုပ်ခဲ့ချိန်၏ compaction count

Store ကို ပြင်ဆင်နိုင်သော်လည်း အာဏာပိုင်မှာ Gateway ဖြစ်သည် — session များ လည်ပတ်နေစဉ် entry များကို ပြန်ရေးခြင်း သို့မဟုတ် ပြန်လည်ဖြည့်တင်းခြင်း ဖြစ်နိုင်သည်။


Transcript ဖွဲ့စည်းပုံ (*.jsonl)

Transcripts များကို @mariozechner/pi-coding-agentSessionManager မှ စီမံခန့်ခွဲသည်။

ဖိုင်ပုံစံမှာ JSONL ဖြစ်သည် —

  • ပထမလိုင်း: session header (type: "session"id, cwd, timestamp, optional parentSession ပါဝင်)
  • ထို့နောက်: id + parentId (tree) ပါသော session entries များ

သတိပြုရန် entry အမျိုးအစားများ —

  • message: user/assistant/toolResult မက်ဆေ့ချ်များ
  • custom_message: model context ထဲသို့ ဝင်သည့် extension ထည့်သွင်းထားသော မက်ဆေ့ချ်များ (UI မှ ဖျောက်ထားနိုင်)
  • custom: model context ထဲသို့ မဝင်သည့် extension state
  • compaction: firstKeptEntryId နှင့် tokensBefore ပါသော သိမ်းဆည်းထားသည့် compaction summary
  • branch_summary: tree branch တစ်ခုသို့ လမ်းကြောင်းပြောင်းသည့်အခါ သိမ်းဆည်းထားသော summary

OpenClaw သည် transcript များကို အလိုအလျောက် ပြုပြင်မလုပ် ပါ — Gateway သည် ဖတ်/ရေးရန် SessionManager ကို အသုံးပြုသည်။


Context windows နှင့် tracked tokens

အရေးပါတာ နှစ်မျိုး ရှိသည် —

  1. Model context window: model တစ်ခုချင်းစီအလိုက် တင်းကျပ်သော အများဆုံးကန့်သတ်ချက် (model မြင်နိုင်သော tokens)
  2. Session store counters: sessions.json ထဲသို့ ရေးသွင်းထားသော rolling stats ( /status နှင့် dashboards အတွက် အသုံးပြု)

Limit များကို ချိန်ညှိနေပါက —

  • Context window သည် model catalog မှ ရလာပြီး (config ဖြင့် override လုပ်နိုင်သည်)။
  • Store ထဲရှိ contextTokens သည် runtime ခန့်မှန်း/အစီရင်ခံတန်ဖိုးသာ ဖြစ်ပြီး တင်းကျပ်သော အာမခံအဖြစ် မယူဆသင့်ပါ။

ပိုမိုသိရှိရန် /token-use ကို ကြည့်ပါ။


Compaction: အဓိပ္ပါယ်

Compaction သည် အဟောင်းပိုင်း စကားပြောများကို transcript ထဲရှိ သိမ်းဆည်းထားသော compaction entry တစ်ခုအဖြစ် အကျဉ်းချုပ်ပြီး နောက်ဆုံး မက်ဆေ့ချ်များကို မပျက်မယွင်း ထားရှိသည်။

Compaction ပြီးနောက် နောက်လာမည့် turn များတွင် —

  • Compaction summary
  • firstKeptEntryId နောက်ပိုင်း မက်ဆေ့ချ်များ

Compaction သည် persistent ဖြစ်ပါသည် (session pruning နှင့် မတူပါ)။ /concepts/session-pruning ကို ကြည့်ပါ။


auto-compaction ဖြစ်ပေါ်လာသည့်အခါ (Pi runtime)

embedded Pi agent တွင် auto-compaction သည် အခြေအနေ နှစ်ခုတွင် trigger ဖြစ်ပါသည် —

  1. Overflow recovery: model သည် context overflow error ကို ပြန်ပေးပါက → compact → retry။
  2. Threshold maintenance: အောင်မြင်သော turn တစ်ခုအပြီးတွင် —

contextTokens > contextWindow - reserveTokens

Where:

  • contextWindow သည် model ၏ context window ဖြစ်ပါသည်။
  • reserveTokens သည် prompts နှင့် နောက်တစ်ကြိမ် model output အတွက် သိုလှောင်ထားသော headroom ဖြစ်ပါသည်။

These are Pi runtime semantics (OpenClaw consumes the events, but Pi decides when to compact).


Compaction settings (reserveTokens, keepRecentTokens)

Pi’s compaction settings live in Pi settings:

{
  compaction: {
    enabled: true,
    reserveTokens: 16384,
    keepRecentTokens: 20000,
  },
}

OpenClaw also enforces a safety floor for embedded runs:

  • If compaction.reserveTokens < reserveTokensFloor, OpenClaw bumps it.
  • Default floor is 20000 tokens.
  • Set agents.defaults.compaction.reserveTokensFloor: 0 to disable the floor.
  • If it’s already higher, OpenClaw leaves it alone.

Why: leave enough headroom for multi-turn “housekeeping” (like memory writes) before compaction becomes unavoidable.

အကြောင်းရင်း — compaction မဖြစ်မနေရောက်မီ multi-turn “housekeeping” (memory write များကဲ့သို့) အတွက် headroom လုံလောက်စွာ ချန်ထားရန်။


User-visible surfaces

You can observe compaction and session state via:

  • /status (in any chat session)
  • openclaw status (CLI)
  • openclaw sessions / sessions --json
  • Verbose mode: 🧹 Auto-compaction complete + compaction count

Silent housekeeping (NO_REPLY)

OpenClaw supports “silent” turns for background tasks where the user should not see intermediate output.

OpenClaw သည် အသုံးပြုသူ မမြင်သင့်သော အလယ်အလတ် output များရှိသည့် နောက်ခံလုပ်ငန်းများအတွက် “silent” turns များကို ပံ့ပိုးသည်။

  • The assistant starts its output with NO_REPLY to indicate “do not deliver a reply to the user”.
  • OpenClaw strips/suppresses this in the delivery layer.

As of 2026.1.10, OpenClaw also suppresses draft/typing streaming when a partial chunk begins with NO_REPLY, so silent operations don’t leak partial output mid-turn.


Pre-compaction “memory flush” (implemented)

Goal: before auto-compaction happens, run a silent agentic turn that writes durable state to disk (e.g. memory/YYYY-MM-DD.md in the agent workspace) so compaction can’t erase critical context.

ရည်ရွယ်ချက် — auto-compaction မဖြစ်မီ disk သို့ durable state (ဥပမာ—agent workspace ထဲရှိ memory/YYYY-MM-DD.md) ကို ရေးသွင်းပေးသော silent agentic turn တစ်ခုကို လုပ်ဆောင်ရန်၊ ထို့ကြောင့် compaction က အရေးကြီးသော context ကို မဖျက်နိုင်ပါ။

  1. Monitor session context usage.
  2. When it crosses a “soft threshold” (below Pi’s compaction threshold), run a silent “write memory now” directive to the agent.
  3. Use NO_REPLY so the user sees nothing.

Config (agents.defaults.compaction.memoryFlush):

  • enabled (default: true)
  • softThresholdTokens (default: 4000)
  • prompt (user message for the flush turn)
  • systemPrompt (extra system prompt appended for the flush turn)

မှတ်ချက်များ-

  • The default prompt/system prompt include a NO_REPLY hint to suppress delivery.
  • The flush runs once per compaction cycle (tracked in sessions.json).
  • The flush runs only for embedded Pi sessions (CLI backends skip it).
  • The flush is skipped when the session workspace is read-only (workspaceAccess: "ro" or "none").
  • See Memory for the workspace file layout and write patterns.

Pi also exposes a session_before_compact hook in the extension API, but OpenClaw’s flush logic lives on the Gateway side today.


Troubleshooting checklist

  • Session key wrong? Start with /concepts/session and confirm the sessionKey in /status.
  • Store vs transcript mismatch? Confirm the Gateway host and the store path from openclaw status.
  • Compaction spam? Check:
  • model context window (too small)
  • compaction settings (reserveTokens too high for the model window can cause earlier compaction)
  • tool-result bloat: enable/tune session pruning
  • Silent turns leaking? Confirm the reply starts with NO_REPLY (exact token) and you’re on a build that includes the streaming suppression fix.