Gateway
Gateway लॉक
क्यों
- सुनिश्चित करें कि उसी होस्ट पर प्रति बेस पोर्ट केवल एक Gateway इंस्टेंस चले; अतिरिक्त Gateway को अलग-थलग प्रोफ़ाइल और अद्वितीय पोर्ट का उपयोग करना होगा।
- क्रैश/SIGKILL के बाद भी stale लॉक फ़ाइलें छोड़े बिना जारी रहें।
- जब कंट्रोल पोर्ट पहले से व्यस्त हो, तो स्पष्ट त्रुटि के साथ तुरंत विफल हों।
तंत्र
- Gateway पहले स्टेट लॉक डायरेक्टरी के तहत प्रति-कॉन्फ़िग लॉक फ़ाइल प्राप्त करता है और किसी मौजूदा listener के लिए कॉन्फ़िगर किए गए पोर्ट की जांच करता है।
- यदि दर्ज किया गया लॉक owner समाप्त हो चुका है, पोर्ट खाली है, या लॉक stale है, तो startup लॉक को फिर से हासिल करता है और जारी रहता है।
- इसके बाद Gateway एक exclusive TCP listener का उपयोग करके HTTP/WebSocket listener (डिफ़ॉल्ट
ws://127.0.0.1:18789) को bind करता है। - यदि bind
EADDRINUSEके साथ विफल होता है, तो startupGatewayLockError("another gateway instance is already listening on ws://127.0.0.1:<port>")फेंकता है। - shutdown पर Gateway HTTP/WebSocket server को बंद करता है और लॉक फ़ाइल हटाता है।
त्रुटि सतह
- यदि कोई दूसरा process पोर्ट को hold कर रहा है, तो startup
GatewayLockError("another gateway instance is already listening on ws://127.0.0.1:<port>")फेंकता है। - अन्य bind विफलताएं
GatewayLockError("failed to bind gateway socket on ws://127.0.0.1:<port>: …")के रूप में सामने आती हैं।
संचालन संबंधी नोट्स
- यदि पोर्ट किसी अन्य process द्वारा occupied है, तो त्रुटि वही रहती है; पोर्ट खाली करें या
openclaw gateway --port <port>के साथ दूसरा चुनें। - किसी service supervisor के तहत, नया Gateway process जो मौजूदा स्वस्थ
/healthzresponder देखता है, उस process को नियंत्रण में रहने देता है। systemd पर, duplicate starter कोड 78 के साथ exit करता है ताकि डिफ़ॉल्टRestartPreventExitStatus=78Restart=alwaysको लॉक याEADDRINUSEconflict पर loop करने से रोक सके। यदि मौजूदा process कभी healthy नहीं बनता, तो retries सीमित रहती हैं और startup हमेशा loop करने के बजाय स्पष्ट लॉक त्रुटि के साथ विफल होता है। - macOS app अभी भी Gateway spawn करने से पहले अपना हल्का PID guard बनाए रखता है; runtime लॉक को लॉक फ़ाइल और HTTP/WebSocket bind द्वारा enforce किया जाता है।
संबंधित
- एकाधिक Gateway — अद्वितीय पोर्ट के साथ कई इंस्टेंस चलाना
- समस्या निवारण —
EADDRINUSEऔर पोर्ट conflicts का निदान करना
Was this useful?