सत्र प्रबंधन एवं संपीड़न (गहन विवेचन)
यह दस्तावेज़ बताता है कि OpenClaw सत्रों को एंड-टू-एंड कैसे प्रबंधित करता है:- सत्र रूटिंग (इनबाउंड संदेश कैसे
sessionKeyसे मैप होते हैं) - सत्र स्टोर (
sessions.json) और यह क्या ट्रैक करता है - ट्रांसक्रिप्ट स्थायित्व (
*.jsonl) और इसकी संरचना - ट्रांसक्रिप्ट स्वच्छता (रन से पहले प्रदाता-विशिष्ट सुधार)
- कॉन्टेक्स्ट सीमाएँ (कॉन्टेक्स्ट विंडो बनाम ट्रैक किए गए टोकन)
- संपीड़न (मैनुअल + स्वचालित-संपीड़न) और प्री-कम्पैक्शन कार्य को कहाँ हुक करें
- जब daily + idle दोनों कॉन्फ़िगर हों, तो जो पहले expire होता है वही लागू होता है।
सत्य का स्रोत: Gateway
OpenClaw को एकल Gateway प्रक्रिया के चारों ओर डिज़ाइन किया गया है जो सत्र स्थिति का स्वामित्व रखती है।- UI (macOS ऐप, वेब Control UI, TUI) को सत्र सूचियों और टोकन गणनाओं के लिए Gateway से क्वेरी करनी चाहिए।
- रिमोट मोड में, सत्र फ़ाइलें रिमोट होस्ट पर होती हैं; “अपने लोकल Mac फ़ाइलें जाँचना” Gateway द्वारा उपयोग किए जा रहे डेटा को प्रतिबिंबित नहीं करेगा।
दो स्थायित्व परतें
OpenClaw सत्रों को दो परतों में स्थायी करता है:-
सत्र स्टोर (
sessions.json)- कुंजी/मान मानचित्र:
sessionKey -> SessionEntry - छोटा, परिवर्तनशील, संपादन (या प्रविष्टियाँ हटाने) के लिए सुरक्षित
- सत्र मेटाडेटा ट्रैक करता है (वर्तमान सत्र आईडी, अंतिम गतिविधि, टॉगल्स, टोकन काउंटर, आदि)
- कुंजी/मान मानचित्र:
-
ट्रांसक्रिप्ट (
<sessionId>.jsonl)- ट्री संरचना के साथ केवल-परिशिष्ट ट्रांसक्रिप्ट (प्रविष्टियों में
id+parentIdहोते हैं) - वास्तविक बातचीत + टूल कॉल्स + संपीड़न सारांश संग्रहीत करता है
- भविष्य के टर्न के लिए मॉडल कॉन्टेक्स्ट पुनर्निर्माण में उपयोग होता है
- ट्री संरचना के साथ केवल-परिशिष्ट ट्रांसक्रिप्ट (प्रविष्टियों में
ऑन-डिस्क स्थान
प्रति एजेंट, Gateway होस्ट पर:- स्टोर:
~/.openclaw/agents/<agentId>/sessions/sessions.json - ट्रांसक्रिप्ट्स:
~/.openclaw/agents/<agentId>/sessions/<sessionId>.jsonl- Telegram टॉपिक सत्र:
.../<sessionId>-topic-<threadId>.jsonl
- Telegram टॉपिक सत्र:
src/config/sessions.ts के माध्यम से रिज़ॉल्व करता है।
सत्र कुंजियाँ (sessionKey)
एक sessionKey यह पहचानता है कि आप किस वार्तालाप बकेट में हैं (रूटिंग + पृथक्करण)।
सामान्य पैटर्न:
- मुख्य/डायरेक्ट चैट (प्रति एजेंट):
agent:<agentId>:<mainKey>(डिफ़ॉल्टmain) - समूह:
agent:<agentId>:<channel>:group:<id> - रूम/चैनल (Discord/Slack):
agent:<agentId>:<channel>:channel:<id>या...:room:<id> - क्रॉन:
cron:<job.id> - वेबहुक:
hook:<uuid>(जब तक ओवरराइड न किया जाए)
सत्र आईडी (sessionId)
प्रत्येक sessionKey एक वर्तमान sessionId की ओर संकेत करता है (वह ट्रांसक्रिप्ट फ़ाइल जो बातचीत को जारी रखती है)।
व्यावहारिक नियम:
- रीसेट (
/new,/reset) उसsessionKeyके लिए एक नयाsessionIdबनाता है। - दैनिक रीसेट (डिफ़ॉल्ट Gateway होस्ट के स्थानीय समयानुसार सुबह 4:00 बजे) रीसेट सीमा के बाद आने वाले अगले संदेश पर एक नया
sessionIdबनाता है। - Compaction persistent है (session pruning के विपरीत)। देखें /concepts/session-pruning।
src/auto-reply/reply/session.ts में initSessionState() में होता है।
सत्र स्टोर स्कीमा (sessions.json)
स्टोर का मान प्रकार src/config/sessions.ts में SessionEntry है।
मुख्य फ़ील्ड्स (पूर्ण सूची नहीं):
sessionId: वर्तमान ट्रांसक्रिप्ट आईडी (फ़ाइलनाम इससे व्युत्पन्न होता है जब तकsessionFileसेट न हो)updatedAt: अंतिम गतिविधि टाइमस्टैम्पsessionFile: वैकल्पिक स्पष्ट ट्रांसक्रिप्ट पथ ओवरराइडchatType:direct | group | room(UI और सेंड नीति में सहायक)provider,subject,room,space,displayName: समूह/चैनल लेबलिंग के लिए मेटाडेटा- टॉगल्स:
thinkingLevel,verboseLevel,reasoningLevel,elevatedLevelsendPolicy(प्रति-सत्र ओवरराइड)
- मॉडल चयन:
providerOverride,modelOverride,authProfileOverride
- टोकन काउंटर (सर्वोत्तम-प्रयास / प्रदाता-निर्भर):
inputTokens,outputTokens,totalTokens,contextTokens
compactionCount: इस सत्र कुंजी के लिए स्वचालित-संपीड़न कितनी बार पूरा हुआmemoryFlushAt: अंतिम प्री-कम्पैक्शन मेमोरी फ्लश का टाइमस्टैम्पmemoryFlushCompactionCount: अंतिम फ्लश के समय का संपीड़न काउंट
ट्रांसक्रिप्ट संरचना (*.jsonl)
ट्रांसक्रिप्ट्स @mariozechner/pi-coding-agent के SessionManager द्वारा प्रबंधित होते हैं।
फ़ाइल JSONL है:
- पहली पंक्ति: सत्र हेडर (
type: "session", जिसमेंid,cwd,timestamp, वैकल्पिकparentSessionशामिल हैं) - फिर:
id+parentId(ट्री) के साथ सत्र प्रविष्टियाँ
message: user/assistant/toolResult संदेशcustom_message: एक्सटेंशन-इंजेक्टेड संदेश जो मॉडल कॉन्टेक्स्ट में प्रवेश करते हैं (UI से छिपाए जा सकते हैं)custom: एक्सटेंशन स्टेट जो मॉडल कॉन्टेक्स्ट में प्रवेश नहीं करताcompaction:firstKeptEntryIdऔरtokensBeforeके साथ स्थायी संपीड़न सारांशbranch_summary: ट्री शाखा नेविगेशन के समय स्थायी सारांश
SessionManager का उपयोग करता है।
कॉन्टेक्स्ट विंडो बनाम ट्रैक किए गए टोकन
दो अलग-अलग अवधारणाएँ महत्वपूर्ण हैं:- मॉडल कॉन्टेक्स्ट विंडो: प्रति मॉडल कठोर सीमा (मॉडल को दिखाई देने वाले टोकन)
- सत्र स्टोर काउंटर:
sessions.jsonमें लिखे गए रोलिंग आँकड़े (/status और डैशबोर्ड के लिए उपयोग)
- कॉन्टेक्स्ट विंडो मॉडल कैटलॉग से आती है (और कॉन्फ़िग के माध्यम से ओवरराइड की जा सकती है)।
- स्टोर में
contextTokensएक रनटाइम अनुमान/रिपोर्टिंग मान है; इसे कठोर गारंटी न मानें।
संपीड़न: यह क्या है
संपीड़न पुराने वार्तालाप को ट्रांसक्रिप्ट में एक स्थायीcompaction प्रविष्टि में सारांशित करता है और हाल के संदेशों को यथावत रखता है।
संपीड़न के बाद, भविष्य के टर्न देखते हैं:
- संपीड़न सारांश
firstKeptEntryIdके बाद के संदेश
memory/YYYY-MM-DD.md), ताकि compaction महत्वपूर्ण context को मिटा न सके। Session key गलत है?
स्वचालित-संपीड़न कब होता है (Pi रनटाइम)
एंबेडेड Pi एजेंट में, स्वचालित-संपीड़न दो स्थितियों में ट्रिगर होता है:- ओवरफ़्लो रिकवरी: मॉडल कॉन्टेक्स्ट ओवरफ़्लो त्रुटि लौटाता है → संपीड़न → पुनः प्रयास।
- थ्रेशहोल्ड मेंटेनेंस: एक सफल टर्न के बाद, जब:
contextTokens > contextWindow - reserveTokens
जहाँ:
contextWindowमॉडल की कॉन्टेक्स्ट विंडो हैreserveTokensप्रॉम्प्ट्स + अगले मॉडल आउटपुट के लिए आरक्षित हेडरूम है
संपीड़न सेटिंग्स (reserveTokens, keepRecentTokens)
Pi की संपीड़न सेटिंग्स Pi सेटिंग्स में रहती हैं:
- यदि
compaction.reserveTokens < reserveTokensFloor, OpenClaw इसे बढ़ाता है। - डिफ़ॉल्ट फ़्लोर
20000टोकन है। - फ़्लोर अक्षम करने के लिए
agents.defaults.compaction.reserveTokensFloor: 0सेट करें। - यदि यह पहले से अधिक है, तो OpenClaw इसे यथावत छोड़ देता है।
src/agents/pi-settings.ts में ensurePiCompactionReserveTokens()
(src/agents/pi-embedded-runner.ts से कॉल किया गया)।
उपयोगकर्ता-दृश्य सतहें
आप संपीड़न और सत्र स्थिति को यहाँ देख सकते हैं:/status(किसी भी चैट सत्र में)openclaw status(CLI)openclaw sessions/sessions --json- वर्बोज़ मोड:
🧹 Auto-compaction complete+ संपीड़न काउंट
साइलेंट हाउसकीपिंग (NO_REPLY)
OpenClaw पृष्ठभूमि कार्यों के लिए “साइलेंट” टर्न का समर्थन करता है, जहाँ उपयोगकर्ता को मध्यवर्ती आउटपुट नहीं दिखना चाहिए।
परंपरा:
- असिस्टेंट अपने आउटपुट की शुरुआत
NO_REPLYसे करता है ताकि “उपयोगकर्ता को उत्तर न दें” संकेतित हो। - OpenClaw डिलीवरी लेयर में इसे स्ट्रिप/दबा देता है।
2026.1.10 से, OpenClaw ड्राफ़्ट/टाइपिंग स्ट्रीमिंग को भी दबाता है जब कोई आंशिक चंक NO_REPLY से शुरू होता है, ताकि साइलेंट ऑपरेशन मध्य-टर्न में आंशिक आउटपुट लीक न करें।
प्री-कम्पैक्शन “मेमोरी फ्लश” (कार्यान्वित)
/concepts/session से शुरू करें और/status में sessionKey की पुष्टि करें।
OpenClaw प्री-थ्रेशहोल्ड फ्लश दृष्टिकोण का उपयोग करता है:
- सत्र कॉन्टेक्स्ट उपयोग की निगरानी।
- जब यह एक “सॉफ्ट थ्रेशहोल्ड” (Pi के संपीड़न थ्रेशहोल्ड से नीचे) पार करता है, तो एक साइलेंट “अब मेमोरी लिखें” निर्देश एजेंट को चलाएँ।
NO_REPLYका उपयोग करें ताकि उपयोगकर्ता को कुछ भी न दिखे।
agents.defaults.compaction.memoryFlush):
enabled(डिफ़ॉल्ट:true)softThresholdTokens(डिफ़ॉल्ट:4000)prompt(फ्लश टर्न के लिए उपयोगकर्ता संदेश)systemPrompt(फ्लश टर्न के लिए जोड़ा गया अतिरिक्त सिस्टम प्रॉम्प्ट)
- डिफ़ॉल्ट प्रॉम्प्ट/सिस्टम प्रॉम्प्ट में डिलीवरी दबाने के लिए
NO_REPLYसंकेत शामिल होता है। - फ्लश प्रति संपीड़न चक्र एक बार चलता है (
sessions.jsonमें ट्रैक किया गया)। - फ्लश केवल एंबेडेड Pi सत्रों के लिए चलता है (CLI बैकएंड इसे छोड़ देते हैं)।
- जब सत्र वर्कस्पेस रीड-ओनली हो (
workspaceAccess: "ro"या"none"), तो फ्लश छोड़ा जाता है। - वर्कस्पेस फ़ाइल लेआउट और राइट पैटर्न के लिए Memory देखें।
session_before_compact हुक भी एक्सपोज़ करता है, लेकिन OpenClaw की
फ्लश लॉजिक आज Gateway पक्ष पर रहती है।
समस्या-निवारण चेकलिस्ट
- Store बनाम transcript mismatch?
openclaw statusसे Gateway host और store path की पुष्टि करें। - Compaction spam? जाँच करें:
- Silent turns लीक हो रहे हैं? पुष्टि करें कि reply
NO_REPLY(exact token) से शुरू होता है और आप उस build पर हैं जिसमें streaming suppression fix शामिल है।- मॉडल कॉन्टेक्स्ट विंडो (बहुत छोटी)
- संपीड़न सेटिंग्स (मॉडल विंडो के लिए
reserveTokensबहुत अधिक होने पर पहले संपीड़न हो सकता है) - टूल-रिज़ल्ट ब्लोट: सत्र प्रूनिंग सक्षम/ट्यून करें
- “Hello, C-3PO! 🤖