बैकग्राउंड Exec + प्रोसेस टूल
- OpenClaw शेल कमांड्स को
execटूल के माध्यम से चलाता है और लंबे समय तक चलने वाले कार्यों को मेमोरी में रखता है। 8.processटूल उन बैकग्राउंड सेशनों को प्रबंधित करता है।
exec टूल
मुख्य पैरामीटर:command(आवश्यक)yieldMs(डिफ़ॉल्ट 10000): इस विलंब के बाद स्वतः बैकग्राउंडbackground(bool): तुरंत बैकग्राउंड करेंtimeout(सेकंड, डिफ़ॉल्ट 1800): इस टाइमआउट के बाद प्रक्रिया समाप्त करेंelevated(bool): यदि उन्नत मोड सक्षम/अनुमत है तो होस्ट पर चलाएँ-
- क्या आपको एक वास्तविक TTY चाहिए? 10.
pty: trueसेट करें।
- क्या आपको एक वास्तविक TTY चाहिए? 10.
workdir,env
- फ़ोरग्राउंड रन सीधे आउटपुट लौटाते हैं।
- जब बैकग्राउंड किया जाता है (स्पष्ट रूप से या टाइमआउट पर), टूल
status: "running"+sessionIdऔर एक छोटा टेल लौटाता है। - आउटपुट तब तक मेमोरी में रखा जाता है जब तक सत्र को पोल या साफ़ नहीं किया जाता।
- यदि
processटूल अस्वीकृत है, तोexecसमकालिक रूप से चलता है औरyieldMs/backgroundको अनदेखा करता है।
चाइल्ड प्रक्रिया ब्रिजिंग
- जब exec/process टूल्स के बाहर लंबे समय तक चलने वाली child processes spawn की जाती हैं (उदाहरण के लिए, CLI respawns या gateway helpers), तो child‑process bridge helper को attach करें ताकि termination signals फ़ॉरवर्ड हों और exit/error पर listeners detach हो जाएँ। 12. इससे systemd पर orphaned processes से बचाव होता है और प्लेटफ़ॉर्म्स के बीच shutdown व्यवहार सुसंगत रहता है।
PI_BASH_YIELD_MS: डिफ़ॉल्ट यील्ड (ms)PI_BASH_MAX_OUTPUT_CHARS: इन‑मेमोरी आउटपुट सीमा (chars)OPENCLAW_BASH_PENDING_MAX_OUTPUT_CHARS: प्रति स्ट्रीम लंबित stdout/stderr सीमा (chars)PI_BASH_JOB_TTL_MS: पूर्ण सत्रों के लिए TTL (ms, 1m–3h तक सीमित)
tools.exec.backgroundMs(डिफ़ॉल्ट 10000)tools.exec.timeoutSec(डिफ़ॉल्ट 1800)tools.exec.cleanupMs(डिफ़ॉल्ट 1800000)tools.exec.notifyOnExit(डिफ़ॉल्ट true): जब कोई बैकग्राउंड exec समाप्त होता है तो एक सिस्टम इवेंट कतारबद्ध करें + अनुरोध हार्टबीट।tools.exec.notifyOnExitEmptySuccess(डिफ़ॉल्ट false): जब true हो, तो उन सफल बैकग्राउंड रन के लिए भी completion events कतारबद्ध करें जिनमें कोई आउटपुट नहीं बना।
process टूल
क्रियाएँ:list: चल रहे + पूर्ण सत्रpoll: किसी सत्र के लिए नया आउटपुट ड्रेन करें (एग्ज़िट स्टेटस भी रिपोर्ट करता है)log: समेकित आउटपुट पढ़ें (offset+limitसमर्थित)write: stdin भेजें (data, वैकल्पिकeof)kill: किसी बैकग्राउंड सत्र को समाप्त करेंclear: मेमोरी से किसी पूर्ण सत्र को हटाएँremove: यदि चल रहा हो तो kill करें, अन्यथा यदि पूर्ण हो तो साफ़ करें
- केवल बैकग्राउंड किए गए सत्र ही सूचीबद्ध/मेमोरी में स्थायी रहते हैं।
- प्रक्रिया पुनः आरंभ पर सत्र खो जाते हैं (डिस्क पर स्थायित्व नहीं)।
- सत्र लॉग केवल चैट इतिहास में सहेजे जाते हैं यदि आप
process poll/logचलाते हैं और टूल परिणाम रिकॉर्ड किया जाता है। processप्रति एजेंट स्कोप्ड है; यह केवल उसी एजेंट द्वारा शुरू किए गए सत्रों को देखता है।process listमें त्वरित स्कैन के लिए एक व्युत्पन्नname(कमांड क्रिया + लक्ष्य) शामिल होता है।process logलाइन‑आधारितoffset/limitका उपयोग करता है (offsetको छोड़ दें ताकि अंतिम N पंक्तियाँ प्राप्त हों)।- जब
offsetऔरlimitदोनों छोड़े जाते हैं, तो यह अंतिम 200 पंक्तियाँ लौटाता है और एक paging संकेत शामिल करता है। - जब
offsetदिया गया हो औरlimitछोड़ा गया हो, तो यहoffsetसे अंत तक लौटाता है (200 तक सीमित नहीं)।