FAQ
سؤالات متداول
پاسخهای سریع بههمراه عیبیابی عمیقتر برای راهاندازیهای واقعی (توسعه محلی، VPS، چندعاملی، OAuth/API keys، failover مدل). برای عیبیابی زمان اجرا، عیبیابی را ببینید. برای مرجع کامل پیکربندی، پیکربندی را ببینید.
۶۰ ثانیه اول اگر چیزی خراب است
-
وضعیت سریع (اولین بررسی)
bash openclaw statusخلاصه محلی سریع: سیستمعامل + بهروزرسانی، دسترسپذیری gateway/service، عاملها/نشستها، پیکربندی provider + مشکلات زمان اجرا (وقتی gateway در دسترس باشد).
-
گزارش قابل چسباندن (ایمن برای اشتراکگذاری)
bash openclaw status --allتشخیص فقطخواندنی با انتهای لاگ (توکنها حذف میشوند).
-
وضعیت Daemon + پورت
bash openclaw gateway statusزمان اجرای supervisor در برابر دسترسپذیری RPC، URL هدف probe، و اینکه service احتمالا از کدام پیکربندی استفاده کرده است را نشان میدهد.
-
probeهای عمیق
bash openclaw status --deepیک probe سلامت زنده Gateway اجرا میکند، شامل probeهای کانال وقتی پشتیبانی شوند (به Gateway قابل دسترس نیاز دارد). سلامت را ببینید.
-
دنبال کردن آخرین لاگ
bash openclaw logs --followاگر RPC قطع است، به این fallback کنید:
bash tail -f "$(ls -t /tmp/openclaw/openclaw-*.log | head -1)"لاگهای فایل از لاگهای service جدا هستند؛ لاگگیری و عیبیابی را ببینید.
-
اجرای doctor (تعمیرها)
bash openclaw doctorپیکربندی/وضعیت را تعمیر/مهاجرت میدهد + بررسیهای سلامت را اجرا میکند. Doctor را ببینید.
-
snapshot Gateway
bash openclaw health --jsonopenclaw health --verbose # shows the target URL + config path on errorsاز Gateway در حال اجرا یک snapshot کامل میخواهد (فقط WS). سلامت را ببینید.
شروع سریع و راهاندازی اولین اجرا
پرسشوپاسخ اولین اجرا — نصب، onboarding، مسیرهای احراز هویت، اشتراکها، خطاهای اولیه — در پرسشهای رایج اولین اجرا قرار دارد.
OpenClaw چیست؟
OpenClaw در یک پاراگراف چیست؟
OpenClaw یک دستیار هوش مصنوعی شخصی است که روی دستگاههای خودتان اجرا میکنید. روی سطحهای پیامرسانیای که از قبل استفاده میکنید پاسخ میدهد (WhatsApp، Telegram، Slack، Mattermost، Discord، Google Chat، Signal، iMessage، WebChat، و Pluginهای کانال همراه مانند QQ Bot) و روی پلتفرمهای پشتیبانیشده میتواند صدا + Canvas زنده هم انجام دهد. Gateway کنترلپلین همیشهروشن است؛ دستیار همان محصول است.
ارزش پیشنهادی
OpenClaw «فقط یک پوشش Claude» نیست. این یک کنترلپلین local-first است که اجازه میدهد یک دستیار توانمند را روی سختافزار خودتان اجرا کنید، از برنامههای چتی که از قبل استفاده میکنید به آن دسترسی داشته باشید، با نشستهای stateful، حافظه و ابزارها - بدون اینکه کنترل جریانهای کاری خود را به یک SaaS میزبانیشده بسپارید.
نکات برجسته:
- دستگاههای شما، دادههای شما: Gateway را هرجا میخواهید اجرا کنید (Mac، Linux، VPS) و workspace + تاریخچه نشست را محلی نگه دارید.
- کانالهای واقعی، نه یک sandbox وب: WhatsApp/Telegram/Slack/Discord/Signal/iMessage/etc، بهعلاوه صدای موبایل و Canvas روی پلتفرمهای پشتیبانیشده.
- مستقل از مدل: از Anthropic، OpenAI، MiniMax، OpenRouter و غیره، با مسیریابی و failover برای هر عامل استفاده کنید.
- گزینه فقطمحلی: مدلهای محلی را اجرا کنید تا اگر بخواهید همه دادهها بتوانند روی دستگاه شما بمانند.
- مسیریابی چندعاملی: عاملهای جداگانه برای هر کانال، حساب یا وظیفه، هرکدام با workspace و پیشفرضهای خودش.
- متنباز و قابل هک: بررسی، گسترش و self-host بدون وابستگی به فروشنده.
همین حالا راهاندازیاش کردم - اول چه کار کنم؟
پروژههای خوب برای شروع:
- ساخت یک وبسایت (WordPress، Shopify، یا یک سایت static ساده).
- نمونهسازی یک اپ موبایل (طرح کلی، صفحهها، برنامه API).
- سازماندهی فایلها و پوشهها (پاکسازی، نامگذاری، برچسبگذاری).
- اتصال Gmail و خودکارسازی خلاصهها یا پیگیریها.
میتواند وظیفههای بزرگ را انجام دهد، اما وقتی آنها را به فازها تقسیم کنید و از زیرعاملها برای کار موازی استفاده کنید بهترین عملکرد را دارد.
پنج کاربرد روزمره اصلی OpenClaw چیست؟
بردهای روزمره معمولا اینطور بهنظر میرسند:
- گزارشهای شخصی: خلاصههای صندوق ورودی، تقویم و خبرهایی که برایتان مهم است.
- پژوهش و پیشنویس: پژوهش سریع، خلاصهها و پیشنویسهای اولیه برای ایمیلها یا docs.
- یادآوریها و پیگیریها: تلنگرها و checklistهای مبتنی بر Cron یا Heartbeat.
- خودکارسازی مرورگر: پر کردن فرمها، جمعآوری داده و تکرار وظیفههای وب.
- هماهنگی بین دستگاهها: یک وظیفه را از گوشی بفرستید، بگذارید Gateway آن را روی یک سرور اجرا کند، و نتیجه را در چت بگیرید.
آیا OpenClaw میتواند در lead gen، outreach، تبلیغات و بلاگها برای یک SaaS کمک کند؟
بله، برای پژوهش، ارزیابی صلاحیت و پیشنویس. میتواند سایتها را اسکن کند، فهرستهای کوتاه بسازد، prospects را خلاصه کند و پیشنویس outreach یا متن تبلیغ بنویسد.
برای outreach یا اجرای تبلیغ، انسان را در حلقه نگه دارید. از spam دوری کنید، قوانین محلی و سیاستهای پلتفرم را رعایت کنید، و هر چیزی را قبل از ارسال بازبینی کنید. ایمنترین الگو این است که OpenClaw پیشنویس کند و شما تایید کنید.
مستندات: امنیت.
مزیتها نسبت به Claude Code برای توسعه وب چیست؟
OpenClaw یک دستیار شخصی و لایه هماهنگی است، نه جایگزین IDE. برای سریعترین چرخه کدنویسی مستقیم داخل یک repo از Claude Code یا Codex استفاده کنید. وقتی حافظه پایدار، دسترسی بین دستگاهها و orchestration ابزار میخواهید از OpenClaw استفاده کنید.
مزیتها:
- حافظه + workspace پایدار در سراسر نشستها
- دسترسی چندپلتفرمی (WhatsApp، Telegram، TUI، WebChat)
- orchestration ابزار (مرورگر، فایلها، زمانبندی، hookها)
- Gateway همیشهروشن (اجرا روی VPS، تعامل از هرجا)
- Nodeها برای مرورگر/صفحهنمایش/دوربین/exec محلی
Showcase: https://openclaw.ai/showcase
Skills و خودکارسازی
چطور Skills را بدون dirty نگه داشتن repo سفارشی کنم؟
بهجای ویرایش نسخه repo از overrideهای مدیریتشده استفاده کنید. تغییرات خود را در ~/.openclaw/skills/<name>/SKILL.md بگذارید (یا از طریق skills.load.extraDirs در ~/.openclaw/openclaw.json یک پوشه اضافه کنید). تقدم این است: <workspace>/skills → <workspace>/.agents/skills → ~/.agents/skills → ~/.openclaw/skills → همراه → skills.load.extraDirs، بنابراین overrideهای مدیریتشده همچنان بدون دست زدن به git بر Skills همراه غلبه میکنند. اگر لازم است Skill بهصورت سراسری نصب باشد اما فقط برای برخی عاملها دیده شود، نسخه مشترک را در ~/.openclaw/skills نگه دارید و visibility را با agents.defaults.skills و agents.list[].skills کنترل کنید. فقط ویرایشهایی که ارزش upstream شدن دارند باید در repo باشند و بهصورت PR ارسال شوند.
آیا میتوانم Skills را از یک پوشه سفارشی load کنم؟
بله. دایرکتوریهای اضافی را از طریق skills.load.extraDirs در ~/.openclaw/openclaw.json اضافه کنید (کمترین تقدم). تقدم پیشفرض این است: <workspace>/skills → <workspace>/.agents/skills → ~/.agents/skills → ~/.openclaw/skills → همراه → skills.load.extraDirs. clawhub بهصورت پیشفرض در ./skills نصب میکند، که OpenClaw در نشست بعدی آن را بهعنوان <workspace>/skills در نظر میگیرد. اگر Skill باید فقط برای عاملهای خاصی دیده شود، آن را با agents.defaults.skills یا agents.list[].skills همراه کنید.
چطور میتوانم برای وظیفههای مختلف از مدلهای متفاوت استفاده کنم؟
الگوهای پشتیبانیشده امروز اینها هستند:
- کارهای Cron: کارهای ایزوله میتوانند برای هر کار یک override
modelتنظیم کنند. - زیرعاملها: وظیفهها را به عاملهای جداگانه با مدلهای پیشفرض متفاوت مسیریابی کنید.
- تعویض درخواستی: از
/modelبرای تعویض مدل نشست فعلی در هر زمان استفاده کنید.
کارهای Cron، مسیریابی چندعاملی، و دستورهای Slash را ببینید.
bot هنگام کار سنگین freeze میشود. چطور آن را offload کنم؟
برای وظیفههای طولانی یا موازی از زیرعاملها استفاده کنید. زیرعاملها در نشست خودشان اجرا میشوند، خلاصهای برمیگردانند و چت اصلی شما را پاسخگو نگه میدارند.
از bot خود بخواهید "spawn a sub-agent for this task" یا از /subagents استفاده کنید.
از /status در چت استفاده کنید تا ببینید Gateway همین حالا چه میکند (و آیا مشغول است یا نه).
نکته توکن: وظیفههای طولانی و زیرعاملها هر دو توکن مصرف میکنند. اگر هزینه دغدغه است، از طریق agents.defaults.subagents.model
یک مدل ارزانتر برای زیرعاملها تنظیم کنید.
مستندات: زیرعاملها، وظیفههای پسزمینه.
نشستهای زیرعامل وابسته به thread در Discord چطور کار میکنند؟
از bindingهای thread استفاده کنید. میتوانید یک thread در Discord را به یک زیرعامل یا هدف نشست bind کنید تا پیامهای follow-up در آن thread روی همان نشست bindشده بمانند.
جریان پایه:
- با
sessions_spawnوthread: truespawn کنید (و در صورت نیازmode: "session"برای follow-up پایدار). - یا با
/focus <target>بهصورت دستی bind کنید. - از
/agentsبرای بررسی وضعیت binding استفاده کنید. - از
/session idle <duration|off>و/session max-age <duration|off>برای کنترل auto-unfocus استفاده کنید. - از
/unfocusبرای جدا کردن thread استفاده کنید.
پیکربندی لازم:
- پیشفرضهای سراسری:
session.threadBindings.enabled،session.threadBindings.idleHours،session.threadBindings.maxAgeHours. - overrideهای Discord:
channels.discord.threadBindings.enabled،channels.discord.threadBindings.idleHours،channels.discord.threadBindings.maxAgeHours. - auto-bind هنگام spawn: مقدار پیشفرض
channels.discord.threadBindings.spawnSessionsبرابرtrueاست؛ برای غیرفعال کردن spawn نشستهای وابسته به thread آن را رویfalseبگذارید.
مستندات: زیرعاملها، Discord، مرجع پیکربندی، دستورهای Slash.
یک زیرعامل تمام شد، اما update تکمیل به جای اشتباه رفت یا اصلا ارسال نشد. چه چیزی را بررسی کنم؟
اول مسیر requester حلشده را بررسی کنید:
- تحویل زیرعامل در completion-mode وقتی thread یا route مکالمه bindشده وجود داشته باشد آن را ترجیح میدهد.
- اگر origin تکمیل فقط یک کانال داشته باشد، OpenClaw به route ذخیرهشده نشست requester fallback میکند (
lastChannel/lastTo/lastAccountId) تا تحویل مستقیم همچنان بتواند موفق شود. - اگر نه route bindشده وجود داشته باشد و نه route ذخیرهشده قابل استفاده، تحویل مستقیم میتواند fail شود و نتیجه بهجای ارسال فوری به چت، به تحویل صفشده نشست fallback میکند.
- targetهای نامعتبر یا stale همچنان میتوانند queue fallback یا شکست نهایی تحویل را اجبار کنند.
- اگر آخرین پاسخ assistant قابل مشاهده child دقیقا توکن silent
NO_REPLY/no_reply، یا دقیقاANNOUNCE_SKIPباشد، OpenClaw بهعمد announce را suppress میکند بهجای اینکه پیشرفت قدیمیتر و stale را ارسال کند. - اگر child بعد از فقط tool callها timeout شود، announce میتواند آن را به یک خلاصه کوتاه از پیشرفت جزئی collapse کند بهجای اینکه خروجی raw ابزار را replay کند.
Debug:
openclaw tasks show <runId-or-sessionKey>مستندات: زیرعاملها، وظیفههای پسزمینه، ابزارهای نشست.
Cron یا یادآوریها اجرا نمیشوند. چه چیزی را بررسی کنم؟
Cron داخل process Gateway اجرا میشود. اگر Gateway بهصورت پیوسته در حال اجرا نباشد، کارهای زمانبندیشده اجرا نمیشوند.
Checklist:
- تایید کنید cron فعال است (
cron.enabled) وOPENCLAW_SKIP_CRONتنظیم نشده است. - بررسی کنید Gateway بهصورت 24/7 در حال اجرا است (بدون sleep/restart).
- تنظیمات timezone برای job را بررسی کنید (
--tzدر برابر timezone میزبان).
Debug:
openclaw cron run <jobId>openclaw cron runs --id <jobId> --limit 50مستندات: کارهای Cron، خودکارسازی.
Cron اجرا شد، اما چیزی به کانال ارسال نشد. چرا؟
ابتدا حالت تحویل را بررسی کنید:
--no-deliver/delivery.mode: "none"یعنی هیچ ارسال پشتیبان از runner مورد انتظار نیست.- هدف اعلامِ گمشده یا نامعتبر (
channel/to) یعنی runner تحویل خروجی را رد کرده است. - شکستهای احراز هویت کانال (
unauthorized,Forbidden) یعنی runner تلاش کرده تحویل دهد اما اعتبارنامهها مانع آن شدهاند. - یک نتیجهٔ ایزولهٔ بیصدا (فقط
NO_REPLY/no_reply) عمدا غیرقابلتحویل در نظر گرفته میشود، بنابراین runner تحویل پشتیبانِ صفشده را نیز سرکوب میکند.
برای کارهای Cron ایزوله، وقتی مسیر چت در دسترس باشد، عامل همچنان میتواند مستقیما با ابزار message
ارسال کند. --announce فقط مسیر پشتیبان runner را برای متن نهاییای کنترل میکند
که عامل قبلا ارسال نکرده است.
اشکالزدایی:
openclaw cron runs --id <jobId> --limit 50openclaw tasks show <runId-or-sessionKey>مستندات: کارهای Cron، کارهای پسزمینه.
چرا یک اجرای Cron ایزوله مدل را عوض کرد یا یک بار دوباره تلاش کرد؟
این معمولا مسیر زندهٔ تعویض مدل است، نه زمانبندی تکراری.
Cron ایزوله میتواند یک واگذاری مدل در زمان اجرا را پایدار کند و وقتی اجرای فعال
LiveSessionModelSwitchError پرتاب میکند، دوباره تلاش کند. تلاش مجدد همان
ارائهدهنده/مدلِ تعویضشده را نگه میدارد، و اگر تعویض شامل override جدیدی برای پروفایل احراز هویت باشد، Cron
آن را نیز پیش از تلاش مجدد پایدار میکند.
قواعد انتخاب مرتبط:
- override مدلِ قلاب Gmail وقتی قابلاعمال باشد، ابتدا برنده میشود.
- سپس
modelدر سطح هر کار. - سپس هر override ذخیرهشدهٔ مدلِ نشست Cron.
- سپس انتخاب عادی مدلِ عامل/پیشفرض.
حلقهٔ تلاش مجدد محدود است. پس از تلاش اولیه بهعلاوهٔ ۲ تلاش مجدد برای تعویض، Cron بهجای حلقهٔ بیپایان متوقف میشود.
اشکالزدایی:
openclaw cron runs --id <jobId> --limit 50openclaw tasks show <runId-or-sessionKey>مستندات: کارهای Cron، cron CLI.
چگونه Skills را روی Linux نصب کنم؟
از فرمانهای بومی openclaw skills استفاده کنید یا Skills را در workspace خود قرار دهید. رابط کاربری Skills در macOS روی Linux در دسترس نیست.
Skills را در https://clawhub.ai مرور کنید.
openclaw skills search "calendar"openclaw skills search --limit 20openclaw skills install <skill-slug>openclaw skills install <skill-slug> --version <version>openclaw skills install <skill-slug> --forceopenclaw skills update --allopenclaw skills list --eligibleopenclaw skills checkopenclaw skills install بومی در دایرکتوری فعال skills/
در workspace مینویسد. CLI جداگانهٔ clawhub را فقط زمانی نصب کنید که بخواهید Skills خودتان را منتشر یا
همگامسازی کنید. برای نصبهای مشترک بین عاملها، Skill را زیر
~/.openclaw/skills قرار دهید و اگر میخواهید محدود کنید کدام عاملها بتوانند آن را ببینند، از
agents.defaults.skills یا
agents.list[].skills استفاده کنید.
آیا OpenClaw میتواند کارها را طبق زمانبندی یا بهصورت پیوسته در پسزمینه اجرا کند؟
بله. از زمانبند Gateway استفاده کنید:
- کارهای Cron برای کارهای زمانبندیشده یا تکرارشونده (در میان راهاندازیهای مجدد پایدار میمانند).
- Heartbeat برای بررسیهای دورهای «نشست اصلی».
- کارهای ایزوله برای عاملهای خودکاری که خلاصه ارسال میکنند یا به چتها تحویل میدهند.
مستندات: کارهای Cron، خودکارسازی، Heartbeat.
آیا میتوانم Skills مخصوص Apple macOS را از Linux اجرا کنم؟
نه مستقیما. Skills مربوط به macOS با metadata.openclaw.os بههمراه باینریهای لازم gate میشوند، و Skills فقط وقتی در prompt سیستم ظاهر میشوند که روی میزبان Gateway واجد شرایط باشند. روی Linux، Skills فقط مخصوص darwin (مانند apple-notes، apple-reminders، things-mac) بارگذاری نمیشوند مگر اینکه gating را override کنید.
سه الگوی پشتیبانیشده دارید:
گزینه A - Gateway را روی Mac اجرا کنید (سادهترین). Gateway را جایی اجرا کنید که باینریهای macOS وجود دارند، سپس از Linux در حالت راهدور یا از طریق Tailscale وصل شوید. Skills بهطور عادی بارگذاری میشوند چون میزبان Gateway، macOS است.
گزینه B - از یک Node مربوط به macOS استفاده کنید (بدون SSH).
Gateway را روی Linux اجرا کنید، یک Node مربوط به macOS را جفت کنید (برنامهٔ نوار منو)، و Node Run Commands را روی Mac روی «همیشه بپرس» یا «همیشه اجازه بده» تنظیم کنید. OpenClaw وقتی باینریهای لازم روی Node وجود داشته باشند، میتواند Skills مخصوص macOS را واجد شرایط بداند. عامل آن Skills را از طریق ابزار nodes اجرا میکند. اگر «همیشه بپرس» را انتخاب کنید، تأیید «همیشه اجازه بده» در prompt آن فرمان را به فهرست مجازها اضافه میکند.
گزینه C - باینریهای macOS را از طریق SSH پروکسی کنید (پیشرفته). Gateway را روی Linux نگه دارید، اما کاری کنید باینریهای CLI لازم به wrapperهای SSH resolve شوند که روی Mac اجرا میشوند. سپس Skill را override کنید تا Linux را مجاز کند و واجد شرایط بماند.
-
برای باینری یک wrapper SSH بسازید (مثال:
memoبرای Apple Notes):bash #!/usr/bin/env bashset -euo pipefailexec ssh -T user@mac-host /opt/homebrew/bin/memo "$@" -
wrapper را روی
PATHدر میزبان Linux قرار دهید (برای مثال~/bin/memo). -
metadata مربوط به Skill را override کنید (workspace یا
~/.openclaw/skills) تا Linux مجاز شود:markdown ---name: apple-notesdescription: Manage Apple Notes via the memo CLI on macOS.metadata: { "openclaw": { "os": ["darwin", "linux"], "requires": { "bins": ["memo"] } } }--- -
یک نشست جدید شروع کنید تا snapshot مربوط به Skills تازهسازی شود.
آیا ادغام Notion یا HeyGen دارید؟
امروز بهصورت داخلی ساخته نشده است.
گزینهها:
- Skill / Plugin سفارشی: بهترین گزینه برای دسترسی API قابلاعتماد است (Notion و HeyGen هر دو API دارند).
- خودکارسازی مرورگر: بدون کد کار میکند اما کندتر و شکنندهتر است.
اگر میخواهید زمینه را برای هر مشتری نگه دارید (workflowهای آژانسی)، یک الگوی ساده این است:
- یک صفحهٔ Notion برای هر مشتری (زمینه + ترجیحات + کار فعال).
- از عامل بخواهید آن صفحه را در ابتدای نشست واکشی کند.
اگر ادغام بومی میخواهید، یک درخواست قابلیت باز کنید یا Skillای بسازید که آن APIها را هدف بگیرد.
نصب Skills:
openclaw skills install <skill-slug>openclaw skills update --allنصبهای بومی در دایرکتوری فعال skills/ در workspace قرار میگیرند. برای Skills مشترک بین عاملها، آنها را در ~/.openclaw/skills/<name>/SKILL.md قرار دهید. اگر فقط برخی عاملها باید یک نصب مشترک را ببینند، agents.defaults.skills یا agents.list[].skills را پیکربندی کنید. برخی Skills انتظار دارند باینریهایی از طریق Homebrew نصب شده باشند؛ روی Linux یعنی Linuxbrew (مدخل FAQ مربوط به Homebrew Linux در بالا را ببینید). Skills، پیکربندی Skills، و ClawHub را ببینید.
چگونه از Chrome موجود و واردشدهٔ خودم با OpenClaw استفاده کنم؟
از پروفایل مرورگر داخلی user استفاده کنید، که از طریق Chrome DevTools MCP متصل میشود:
openclaw browser --browser-profile user tabsopenclaw browser --browser-profile user snapshotاگر نام سفارشی میخواهید، یک پروفایل MCP صریح بسازید:
openclaw browser create-profile --name chrome-live --driver existing-sessionopenclaw browser --browser-profile chrome-live tabsاین مسیر میتواند از مرورگر میزبان local یا یک Node مرورگر متصل استفاده کند. اگر Gateway جای دیگری اجرا میشود، یا روی ماشین مرورگر یک میزبان Node اجرا کنید یا بهجای آن از CDP راهدور استفاده کنید.
محدودیتهای فعلی برای existing-session / user:
- actionها بر پایهٔ ref هستند، نه بر پایهٔ CSS selector
- uploadها به
ref/inputRefنیاز دارند و فعلا هر بار از یک فایل پشتیبانی میکنند responsebody، خروجی PDF، رهگیری download، و actionهای batch هنوز به یک مرورگر مدیریتشده یا پروفایل CDP خام نیاز دارند
Sandboxing و حافظه
آیا مستندات اختصاصی sandboxing وجود دارد؟
بله. Sandboxing را ببینید. برای راهاندازی مخصوص Docker (Gateway کامل در Docker یا imageهای sandbox)، Docker را ببینید.
Docker محدود به نظر میرسد - چگونه قابلیتهای کامل را فعال کنم؟
image پیشفرض با اولویت امنیت است و بهعنوان کاربر node اجرا میشود، بنابراین
packageهای سیستم، Homebrew، یا مرورگرهای bundled را شامل نمیشود. برای راهاندازی کاملتر:
/home/nodeرا باOPENCLAW_HOME_VOLUMEپایدار کنید تا cacheها باقی بمانند.- وابستگیهای سیستم را با
OPENCLAW_DOCKER_APT_PACKAGESدر image bake کنید. - مرورگرهای Playwright را از طریق CLI bundled نصب کنید:
node /app/node_modules/playwright-core/cli.js install chromium PLAYWRIGHT_BROWSERS_PATHرا تنظیم کنید و مطمئن شوید مسیر پایدار میماند.
آیا میتوانم DMها را شخصی نگه دارم اما گروهها را با یک عامل عمومی/sandboxed کنم؟
بله - اگر ترافیک خصوصی شما DMها و ترافیک عمومی شما گروهها باشد.
از agents.defaults.sandbox.mode: "non-main" استفاده کنید تا نشستهای گروه/کانال (کلیدهای غیر اصلی) در backend پیکربندیشدهٔ sandbox اجرا شوند، در حالی که نشست اصلی DM روی میزبان بماند. اگر backendای انتخاب نکنید، Docker پیشفرض است. سپس از طریق tools.sandbox.tools محدود کنید چه ابزارهایی در نشستهای sandboxed در دسترس باشند.
راهنمای گامبهگام راهاندازی + پیکربندی نمونه: گروهها: DMهای شخصی + گروههای عمومی
مرجع کلیدی پیکربندی: پیکربندی Gateway
چگونه یک پوشهٔ میزبان را به sandbox bind کنم؟
agents.defaults.sandbox.docker.binds را روی ["host:path:mode"] تنظیم کنید (مثلا "/home/user/src:/src:ro"). bindهای سراسری + سطح عامل merge میشوند؛ bindهای سطح عامل وقتی scope: "shared" باشد نادیده گرفته میشوند. برای هر چیز حساس از :ro استفاده کنید و به یاد داشته باشید bindها دیوارهای فایلسیستم sandbox را دور میزنند.
OpenClaw منبعهای bind را هم در برابر مسیر نرمالشده و هم مسیر canonical که از طریق عمیقترین ancestor موجود resolve شده اعتبارسنجی میکند. این یعنی escapeهای symlink-parent حتی وقتی آخرین segment مسیر هنوز وجود ندارد هم fail closed میشوند، و بررسیهای allowed-root همچنان پس از resolve شدن symlink اعمال میشوند.
برای نمونهها و نکات ایمنی، Sandboxing و Sandbox در برابر سیاست ابزار در برابر Elevated را ببینید.
حافظه چگونه کار میکند؟
حافظهٔ OpenClaw فقط فایلهای Markdown در workspace عامل است:
- یادداشتهای روزانه در
memory/YYYY-MM-DD.md - یادداشتهای بلندمدت curated در
MEMORY.md(فقط نشستهای اصلی/خصوصی)
OpenClaw همچنین یک flush حافظهٔ بیصدای پیش از Compaction اجرا میکند تا به مدل یادآوری کند پیش از auto-compaction یادداشتهای بادوام بنویسد. این فقط وقتی اجرا میشود که workspace قابلنوشتن باشد (sandboxهای فقطخواندنی آن را رد میکنند). حافظه را ببینید.
حافظه مدام چیزها را فراموش میکند. چگونه آن را ماندگار کنم؟
از ربات بخواهید آن واقعیت را در حافظه بنویسد. یادداشتهای بلندمدت متعلق به MEMORY.md هستند،
زمینهٔ کوتاهمدت در memory/YYYY-MM-DD.md قرار میگیرد.
این هنوز حوزهای است که در حال بهبود آن هستیم. یادآوری به مدل برای ذخیرهٔ حافظهها کمک میکند؛ خودش میداند چه کار کند. اگر همچنان فراموش میکند، بررسی کنید Gateway در هر اجرا از همان workspace استفاده میکند.
مستندات: حافظه، workspace عامل.
آیا حافظه برای همیشه پایدار میماند؟ محدودیتها چیست؟
فایلهای حافظه روی دیسک زندگی میکنند و تا وقتی آنها را حذف نکنید پایدار میمانند. محدودیت، فضای ذخیرهسازی شماست، نه مدل. زمینهٔ نشست همچنان با پنجرهٔ زمینهٔ مدل محدود است، بنابراین گفتگوهای طولانی میتوانند compact یا truncate شوند. به همین دلیل جستجوی حافظه وجود دارد - فقط بخشهای مرتبط را دوباره به زمینه برمیگرداند.
آیا جستوجوی حافظهٔ معنایی به کلید API از OpenAI نیاز دارد؟
فقط اگر از embeddings متعلق به OpenAI استفاده کنید. OAuth مربوط به Codex چت/تکمیلها را پوشش میدهد و
دسترسی به embeddings را اعطا نمیکند، بنابراین ورود با Codex (OAuth یا
ورود Codex CLI) برای جستوجوی حافظهٔ معنایی کمکی نمیکند. embeddings متعلق به OpenAI
همچنان به یک کلید API واقعی نیاز دارند (OPENAI_API_KEY یا models.providers.openai.apiKey).
اگر ارائهدهندهای را صراحتا تنظیم نکنید، OpenClaw وقتی بتواند یک کلید API را
پیدا کند، بهطور خودکار یک ارائهدهنده را انتخاب میکند (نمایههای احراز هویت، models.providers.*.apiKey، یا متغیرهای محیطی).
اگر کلید OpenAI پیدا شود، OpenAI را ترجیح میدهد؛ در غیر این صورت اگر کلید Gemini
پیدا شود Gemini را، سپس Voyage، سپس Mistral. اگر هیچ کلید راهدوری در دسترس نباشد، جستوجوی حافظه
تا زمانی که آن را پیکربندی کنید غیرفعال میماند. اگر مسیر مدل محلی
پیکربندیشده و موجود داشته باشید، OpenClaw
local را ترجیح میدهد. وقتی صراحتا
memorySearch.provider = "ollama" را تنظیم کنید، Ollama پشتیبانی میشود.
اگر ترجیح میدهید محلی بمانید، memorySearch.provider = "local" را تنظیم کنید (و در صورت تمایل
memorySearch.fallback = "none"). اگر embeddings متعلق به Gemini را میخواهید،
memorySearch.provider = "gemini" را تنظیم کنید و GEMINI_API_KEY (یا
memorySearch.remote.apiKey) را ارائه دهید. ما از مدلهای embedding مربوط به OpenAI، Gemini، Voyage، Mistral، Ollama، یا local
پشتیبانی میکنیم - برای جزئیات راهاندازی، حافظه را ببینید.
چیزها کجا روی دیسک قرار دارند
آیا همهٔ دادههای استفادهشده با OpenClaw بهصورت محلی ذخیره میشوند؟
نه - وضعیت OpenClaw محلی است، اما سرویسهای خارجی همچنان آنچه را برایشان میفرستید میبینند.
- محلی بهصورت پیشفرض: نشستها، فایلهای حافظه، پیکربندی، و فضای کاری روی میزبان Gateway قرار دارند
(
~/.openclaw+ دایرکتوری فضای کاری شما). - راهدور از روی ضرورت: پیامهایی که به ارائهدهندگان مدل (Anthropic/OpenAI/غیره) میفرستید به APIهای آنها میروند، و پلتفرمهای چت (WhatsApp/Telegram/Slack/غیره) دادههای پیام را روی سرورهای خودشان ذخیره میکنند.
- ردپا را شما کنترل میکنید: استفاده از مدلهای محلی promptها را روی دستگاه شما نگه میدارد، اما ترافیک کانال همچنان از سرورهای همان کانال عبور میکند.
مرتبط: فضای کاری عامل، حافظه.
OpenClaw دادههایش را کجا ذخیره میکند؟
همهچیز زیر $OPENCLAW_STATE_DIR قرار دارد (پیشفرض: ~/.openclaw):
| مسیر | کاربرد |
|---|---|
$OPENCLAW_STATE_DIR/openclaw.json |
پیکربندی اصلی (JSON5) |
$OPENCLAW_STATE_DIR/credentials/oauth.json |
واردسازی OAuth قدیمی (در اولین استفاده در نمایههای احراز هویت کپی میشود) |
$OPENCLAW_STATE_DIR/agents/<agentId>/agent/auth-profiles.json |
نمایههای احراز هویت (OAuth، کلیدهای API، و keyRef/tokenRef اختیاری) |
$OPENCLAW_STATE_DIR/secrets.json |
payload اختیاری راز مبتنی بر فایل برای ارائهدهندگان SecretRef از نوع file |
$OPENCLAW_STATE_DIR/agents/<agentId>/agent/auth.json |
فایل سازگاری قدیمی (ورودیهای ثابت api_key پاکسازی شدهاند) |
$OPENCLAW_STATE_DIR/credentials/ |
وضعیت ارائهدهنده (مثلا whatsapp/<accountId>/creds.json) |
$OPENCLAW_STATE_DIR/agents/ |
وضعیت جداگانه برای هر عامل (agentDir + نشستها) |
$OPENCLAW_STATE_DIR/agents/<agentId>/sessions/ |
تاریخچه و وضعیت گفتوگو (برای هر عامل) |
$OPENCLAW_STATE_DIR/agents/<agentId>/sessions/sessions.json |
فرادادهٔ نشست (برای هر عامل) |
مسیر قدیمی تکعاملی: ~/.openclaw/agent/* (با openclaw doctor مهاجرت داده میشود).
فضای کاری شما (AGENTS.md، فایلهای حافظه، skills، و غیره) جداست و از طریق agents.defaults.workspace پیکربندی میشود (پیشفرض: ~/.openclaw/workspace).
AGENTS.md / SOUL.md / USER.md / MEMORY.md باید کجا قرار بگیرند؟
این فایلها در فضای کاری عامل قرار میگیرند، نه در ~/.openclaw.
- فضای کاری (برای هر عامل):
AGENTS.md،SOUL.md،IDENTITY.md،USER.md،MEMORY.md،memory/YYYY-MM-DD.md، وHEARTBEAT.mdاختیاری. ریشهٔ کوچکحروفmemory.mdفقط ورودی ترمیم قدیمی است؛openclaw doctor --fixوقتی هر دو فایل وجود داشته باشند میتواند آن را درMEMORY.mdادغام کند. - دایرکتوری وضعیت (
~/.openclaw): پیکربندی، وضعیت کانال/ارائهدهنده، نمایههای احراز هویت، نشستها، لاگها، و skills مشترک (~/.openclaw/skills).
فضای کاری پیشفرض ~/.openclaw/workspace است و از این طریق قابل پیکربندی است:
{ agents: { defaults: { workspace: "~/.openclaw/workspace" } },}اگر ربات پس از راهاندازی مجدد «فراموش» میکند، تایید کنید که Gateway در هر بار اجرا از همان فضای کاری استفاده میکند (و به خاطر داشته باشید: حالت راهدور از فضای کاری میزبان gateway استفاده میکند، نه لپتاپ محلی شما).
نکته: اگر یک رفتار یا ترجیح پایدار میخواهید، از ربات بخواهید آن را در AGENTS.md یا MEMORY.md بنویسد، نه اینکه به تاریخچهٔ چت تکیه کند.
فضای کاری عامل و حافظه را ببینید.
راهبرد پیشنهادی پشتیبانگیری
فضای کاری عامل خود را در یک مخزن git خصوصی قرار دهید و آن را در جایی خصوصی (برای مثال GitHub خصوصی) پشتیبانگیری کنید. این کار حافظه + فایلهای AGENTS/SOUL/USER را ثبت میکند و به شما اجازه میدهد بعدا «ذهن» دستیار را بازیابی کنید.
هیچ چیزی را از زیر ~/.openclaw commit نکنید (اعتبارنامهها، نشستها، توکنها، یا payloadهای رمزگذاریشدهٔ راز).
اگر به بازیابی کامل نیاز دارید، هم از فضای کاری و هم از دایرکتوری وضعیت
جداگانه پشتیبان بگیرید (پرسش مهاجرت بالا را ببینید).
مستندات: فضای کاری عامل.
چطور OpenClaw را کاملا حذف نصب کنم؟
راهنمای اختصاصی را ببینید: حذف نصب.
آیا عاملها میتوانند بیرون از فضای کاری کار کنند؟
بله. فضای کاری cwd پیشفرض و لنگر حافظه است، نه یک sandbox سختگیرانه.
مسیرهای نسبی داخل فضای کاری resolve میشوند، اما مسیرهای مطلق میتوانند به مکانهای دیگر
میزبان دسترسی داشته باشند مگر اینکه sandboxing فعال باشد. اگر به جداسازی نیاز دارید، از
agents.defaults.sandbox یا تنظیمات sandbox جداگانهٔ هر عامل استفاده کنید. اگر
میخواهید یک مخزن دایرکتوری کاری پیشفرض باشد، workspace آن عامل را به ریشهٔ مخزن
اشاره دهید. مخزن OpenClaw فقط کد منبع است؛ مگر اینکه عمدا بخواهید عامل داخل آن کار کند،
فضای کاری را جدا نگه دارید.
مثال (مخزن بهعنوان cwd پیشفرض):
{ agents: { defaults: { workspace: "~/Projects/my-repo", }, },}حالت راهدور: محل ذخیرهٔ نشست کجاست؟
وضعیت نشست در مالکیت میزبان gateway است. اگر در حالت راهدور هستید، محل ذخیرهٔ نشستی که برایتان مهم است روی دستگاه راهدور است، نه لپتاپ محلی شما. مدیریت نشست را ببینید.
مبانی پیکربندی
قالب پیکربندی چیست؟ کجاست؟
OpenClaw یک پیکربندی JSON5 اختیاری را از $OPENCLAW_CONFIG_PATH میخواند (پیشفرض: ~/.openclaw/openclaw.json):
$OPENCLAW_CONFIG_PATHاگر فایل وجود نداشته باشد، از پیشفرضهای نسبتا امن استفاده میکند (از جمله فضای کاری پیشفرض ~/.openclaw/workspace).
من gateway.bind: "lan" (یا "tailnet") را تنظیم کردم و حالا هیچ چیزی گوش نمیدهد / UI میگوید غیرمجاز است
bindهای غیر loopback به یک مسیر معتبر احراز هویت gateway نیاز دارند. در عمل یعنی:
- احراز هویت با shared-secret: توکن یا گذرواژه
gateway.auth.mode: "trusted-proxy"پشت یک reverse proxy آگاه از هویت که درست پیکربندی شده باشد
{ gateway: { bind: "lan", auth: { mode: "token", token: "replace-me", }, },}نکتهها:
gateway.remote.token/.passwordبهتنهایی احراز هویت gateway محلی را فعال نمیکنند.- مسیرهای فراخوانی محلی فقط وقتی
gateway.auth.*تنظیم نشده باشد میتوانند ازgateway.remote.*بهعنوان fallback استفاده کنند. - برای احراز هویت با گذرواژه، بهجای آن
gateway.auth.mode: "password"را همراه باgateway.auth.password(یاOPENCLAW_GATEWAY_PASSWORD) تنظیم کنید. - اگر
gateway.auth.token/gateway.auth.passwordصراحتا از طریق SecretRef پیکربندی شده و resolve نشده باشد، resolution بهصورت بسته شکست میخورد (بدون پوشاندن با fallback راهدور). - راهاندازیهای Control UI با shared-secret از طریق
connect.params.auth.tokenیاconnect.params.auth.passwordاحراز هویت میشوند (در تنظیمات app/UI ذخیره میشود). حالتهای دارای هویت مانند Tailscale Serve یاtrusted-proxyبهجای آن از headerهای درخواست استفاده میکنند. از قرار دادن shared secretها در URLها خودداری کنید. - با
gateway.auth.mode: "trusted-proxy"، reverse proxyهای loopback روی همان میزبان بهgateway.auth.trustedProxy.allowLoopback = trueصریح و یک ورودی loopback درgateway.trustedProxiesنیاز دارند.
چرا حالا روی localhost به توکن نیاز دارم؟
OpenClaw احراز هویت gateway را بهصورت پیشفرض اعمال میکند، از جمله loopback. در مسیر پیشفرض معمولی، این یعنی احراز هویت توکنی: اگر هیچ مسیر احراز هویت صریحی پیکربندی نشده باشد، راهاندازی gateway به حالت توکن resolve میشود و برای همان راهاندازی یک توکن فقط زمان اجرا تولید میکند، بنابراین کلاینتهای WS محلی باید احراز هویت شوند. وقتی کلاینتها به راز پایدار بین راهاندازیهای مجدد نیاز دارند، gateway.auth.token، gateway.auth.password، OPENCLAW_GATEWAY_TOKEN، یا OPENCLAW_GATEWAY_PASSWORD را صراحتا پیکربندی کنید. این کار جلوی فراخوانی Gateway توسط فرایندهای محلی دیگر را میگیرد.
اگر مسیر احراز هویت متفاوتی ترجیح میدهید، میتوانید صراحتا حالت گذرواژه را انتخاب کنید (یا برای reverse proxyهای آگاه از هویت، trusted-proxy). اگر واقعا loopback باز میخواهید، در پیکربندی خود gateway.auth.mode: "none" را صراحتا تنظیم کنید. Doctor هر زمان میتواند برایتان توکن تولید کند: openclaw doctor --generate-gateway-token.
آیا پس از تغییر پیکربندی باید راهاندازی مجدد کنم؟
Gateway پیکربندی را پایش میکند و از hot-reload پشتیبانی میکند:
gateway.reload.mode: "hybrid"(پیشفرض): تغییرات امن را بهصورت hot اعمال میکند، برای تغییرات حیاتی راهاندازی مجدد میکندhot،restart،offنیز پشتیبانی میشوند
چطور taglineهای بامزهٔ CLI را غیرفعال کنم؟
cli.banner.taglineMode را در پیکربندی تنظیم کنید:
{ cli: { banner: { taglineMode: "off", // random | default | off }, },}off: متن tagline را پنهان میکند اما خط عنوان/نسخهٔ banner را نگه میدارد.default: هر بار ازAll your chats, one OpenClaw.استفاده میکند.random: taglineهای بامزه/فصلی چرخشی (رفتار پیشفرض).- اگر اصلا banner نمیخواهید، env
OPENCLAW_HIDE_BANNER=1را تنظیم کنید.
چطور جستوجوی وب (و واکشی وب) را فعال کنم؟
web_fetch بدون کلید API کار میکند. web_search به ارائهدهندهٔ انتخابشدهٔ شما
بستگی دارد:
- ارائهدهندگان مبتنی بر API مانند Brave، Exa، Firecrawl، Gemini، Grok، Kimi، MiniMax Search، Perplexity، و Tavily به راهاندازی کلید API معمول خود نیاز دارند.
- Ollama Web Search بدون کلید است، اما از میزبان Ollama پیکربندیشدهٔ شما استفاده میکند و به
ollama signinنیاز دارد. - DuckDuckGo بدون کلید است، اما یک integration غیررسمی مبتنی بر HTML است.
- SearXNG بدون کلید/خودمیزبان است؛
SEARXNG_BASE_URLیاplugins.entries.searxng.config.webSearch.baseUrlرا پیکربندی کنید.
پیشنهاد میشود: openclaw configure --section web را اجرا کنید و یک ارائهدهنده انتخاب کنید.
جایگزینهای محیطی:
- Brave:
BRAVE_API_KEY - Exa:
EXA_API_KEY - Firecrawl:
FIRECRAWL_API_KEY - Gemini:
GEMINI_API_KEY - Grok:
XAI_API_KEY - Kimi:
KIMI_API_KEYیاMOONSHOT_API_KEY - MiniMax Search:
MINIMAX_CODE_PLAN_KEY،MINIMAX_CODING_API_KEY، یاMINIMAX_API_KEY - Perplexity:
PERPLEXITY_API_KEYیاOPENROUTER_API_KEY - SearXNG:
SEARXNG_BASE_URL - Tavily:
TAVILY_API_KEY
{ plugins: { entries: { brave: { config: { webSearch: { apiKey: "BRAVE_API_KEY_HERE", }, }, }, }, }, tools: { web: { search: { enabled: true, provider: "brave", maxResults: 5, }, fetch: { enabled: true, provider: "firecrawl", // optional; omit for auto-detect }, }, },}پیکربندی جستوجوی وب ویژهٔ هر ارائهدهنده اکنون زیر plugins.entries.<plugin>.config.webSearch.* قرار دارد.
مسیرهای قدیمی ارائهدهنده در tools.web.search.* فعلاً برای سازگاری بارگذاری میشوند، اما نباید برای پیکربندیهای جدید استفاده شوند.
پیکربندی جایگزین واکشی وب Firecrawl زیر plugins.entries.firecrawl.config.webFetch.* قرار دارد.
نکات:
- اگر از فهرستهای مجاز استفاده میکنید،
web_search/web_fetch/x_searchیاgroup:webرا اضافه کنید. web_fetchبهطور پیشفرض فعال است (مگر اینکه صریحاً غیرفعال شده باشد).- اگر
tools.web.fetch.providerحذف شود، OpenClaw نخستین ارائهدهندهٔ جایگزین آمادهٔ واکشی را از میان اعتبارنامههای موجود بهطور خودکار شناسایی میکند. امروز ارائهدهندهٔ همراه Firecrawl است. - دیمونها متغیرهای محیطی را از
~/.openclaw/.env(یا محیط سرویس) میخوانند.
مستندات: ابزارهای وب.
config.apply پیکربندی من را پاک کرد. چگونه بازیابی کنم و جلوی آن را بگیرم؟
config.apply کل پیکربندی را جایگزین میکند. اگر یک شیء جزئی ارسال کنید، همهچیز
دیگر حذف میشود.
نسخهٔ فعلی OpenClaw از بسیاری بازنویسیهای تصادفی جلوگیری میکند:
- نوشتنهای پیکربندی متعلق به OpenClaw، پیش از نوشتن، کل پیکربندی پس از تغییر را اعتبارسنجی میکنند.
- نوشتنهای نامعتبر یا مخرب متعلق به OpenClaw رد میشوند و بهصورت
openclaw.json.rejected.*ذخیره میشوند. - اگر یک ویرایش مستقیم راهاندازی یا بارگذاری مجدد داغ را خراب کند، Gateway بسته شکست میخورد یا بارگذاری مجدد را رد میکند؛
openclaw.jsonرا بازنویسی نمیکند. openclaw doctor --fixمالک تعمیر است و میتواند آخرین نسخهٔ سالم شناختهشده را بازیابی کند و در همان حال فایل ردشده را بهصورتopenclaw.json.clobbered.*ذخیره کند.
بازیابی:
openclaw logs --followرا برایInvalid config at،Config write rejected:، یاconfig reload skipped (invalid config)بررسی کنید.- تازهترین
openclaw.json.clobbered.*یاopenclaw.json.rejected.*کنار پیکربندی فعال را بررسی کنید. openclaw config validateوopenclaw doctor --fixرا اجرا کنید.- فقط کلیدهای موردنظر را با
openclaw config setیاconfig.patchبرگردانید. - اگر آخرین نسخهٔ سالم شناختهشده یا محتوای ردشده ندارید، از پشتیبان بازیابی کنید، یا
openclaw doctorرا دوباره اجرا کنید و کانالها/مدلها را دوباره پیکربندی کنید. - اگر این غیرمنتظره بود، یک باگ ثبت کنید و آخرین پیکربندی شناختهشده یا هر نسخهٔ پشتیبان را ضمیمه کنید.
- یک عامل کدنویسی محلی اغلب میتواند از روی لاگها یا تاریخچه یک پیکربندی کارا را بازسازی کند.
جلوگیری:
- برای تغییرات کوچک از
openclaw config setاستفاده کنید. - برای ویرایشهای تعاملی از
openclaw configureاستفاده کنید. - وقتی دربارهٔ مسیر دقیق یا شکل فیلد مطمئن نیستید، ابتدا از
config.schema.lookupاستفاده کنید؛ این فرمان یک گرهٔ سطحی از schema بههمراه خلاصههای فرزند بلافصل برای کاوش عمیقتر برمیگرداند. - برای ویرایشهای جزئی RPC از
config.patchاستفاده کنید؛config.applyرا فقط برای جایگزینی کامل پیکربندی نگه دارید. - اگر از ابزار فقط-مالک
gatewayدر اجرای یک عامل استفاده میکنید، همچنان نوشتن درtools.exec.ask/tools.exec.security(از جمله نامهای مستعار قدیمیtools.bash.*که به همان مسیرهای محافظتشدهٔ exec نرمالسازی میشوند) را رد خواهد کرد.
مستندات: پیکربندی، پیکربندی تعاملی، عیبیابی Gateway، Doctor.
چگونه یک Gateway مرکزی با کارگرهای تخصصی روی دستگاههای مختلف اجرا کنم؟
الگوی رایج یک Gateway (مثلاً Raspberry Pi) بههمراه نودها و عاملها است:
- Gateway (مرکزی): مالک کانالها (Signal/WhatsApp)، مسیریابی، و نشستهاست.
- نودها (دستگاهها): Mac/iOS/Android بهعنوان ابزارهای جانبی متصل میشوند و ابزارهای محلی (
system.run،canvas،camera) را ارائه میکنند. - عاملها (کارگرها): مغزها/فضاهای کاری جدا برای نقشهای خاص (مثلاً "عملیات Hetzner"، "دادههای شخصی").
- زیرعاملها: وقتی موازیسازی میخواهید، کار پسزمینه را از یک عامل اصلی ایجاد میکنند.
- TUI: به Gateway وصل شوید و بین عاملها/نشستها جابهجا شوید.
مستندات: نودها، دسترسی از راه دور، مسیریابی چندعاملی، زیرعاملها، TUI.
آیا مرورگر OpenClaw میتواند headless اجرا شود؟
بله. این یک گزینهٔ پیکربندی است:
{ browser: { headless: true }, agents: { defaults: { sandbox: { browser: { headless: true } }, }, },}مقدار پیشفرض false است (با رابط گرافیکی). حالت headless در برخی سایتها بیشتر احتمال دارد بررسیهای ضدربات را فعال کند. مرورگر را ببینید.
حالت headless از همان موتور Chromium استفاده میکند و برای بیشتر خودکارسازیها (فرمها، کلیکها، scraping، ورودها) کار میکند. تفاوتهای اصلی:
- پنجرهٔ مرورگر قابلمشاهدهای وجود ندارد (اگر به تصویر نیاز دارید از اسکرینشات استفاده کنید).
- برخی سایتها دربارهٔ خودکارسازی در حالت headless سختگیرترند (CAPTCHAها، ضدربات). برای مثال، X/Twitter اغلب نشستهای headless را مسدود میکند.
چگونه از Brave برای کنترل مرورگر استفاده کنم؟
browser.executablePath را روی باینری Brave خود (یا هر مرورگر مبتنی بر Chromium) تنظیم کنید و Gateway را دوباره راهاندازی کنید.
نمونههای کامل پیکربندی را در مرورگر ببینید.
Gatewayها و نودهای راه دور
فرمانها چگونه بین Telegram، gateway، و نودها منتشر میشوند؟
پیامهای Telegram توسط gateway مدیریت میشوند. gateway عامل را اجرا میکند و فقط وقتی به ابزار نود نیاز باشد، سپس از طریق Gateway WebSocket نودها را فراخوانی میکند:
Telegram → Gateway → عامل → node.* → نود → Gateway → Telegram
نودها ترافیک ورودی ارائهدهنده را نمیبینند؛ آنها فقط فراخوانیهای RPC نود را دریافت میکنند.
اگر Gateway از راه دور میزبانی شود، عامل من چگونه میتواند به رایانهٔ من دسترسی داشته باشد؟
پاسخ کوتاه: رایانهٔ خود را بهعنوان یک نود جفت کنید. Gateway در جای دیگری اجرا میشود، اما میتواند
ابزارهای node.* (صفحهنمایش، دوربین، سیستم) را روی دستگاه محلی شما از طریق Gateway WebSocket فراخوانی کند.
راهاندازی معمول:
-
Gateway را روی میزبان همیشهروشن (VPS/سرور خانگی) اجرا کنید.
-
میزبان Gateway و رایانهٔ خود را در یک tailnet قرار دهید.
-
مطمئن شوید Gateway WS قابل دسترس است (اتصال tailnet یا تونل SSH).
-
برنامهٔ macOS را بهصورت محلی باز کنید و در حالت Remote over SSH (یا tailnet مستقیم) وصل شوید تا بتواند بهعنوان نود ثبت شود.
-
نود را روی Gateway تأیید کنید:
bash openclaw devices listopenclaw devices approve <requestId>
به پل TCP جداگانهای نیاز نیست؛ نودها از طریق Gateway WebSocket وصل میشوند.
یادآوری امنیتی: جفتکردن یک نود macOS امکان system.run را روی آن دستگاه فراهم میکند. فقط
دستگاههایی را جفت کنید که به آنها اعتماد دارید، و امنیت را مرور کنید.
مستندات: نودها، پروتکل Gateway، حالت راه دور macOS، امنیت.
Tailscale وصل است اما پاسخی دریافت نمیکنم. حالا چه کنم؟
موارد پایه را بررسی کنید:
- Gateway در حال اجراست:
openclaw gateway status - سلامت Gateway:
openclaw status - سلامت کانال:
openclaw channels status
سپس احراز هویت و مسیریابی را بررسی کنید:
- اگر از Tailscale Serve استفاده میکنید، مطمئن شوید
gateway.auth.allowTailscaleدرست تنظیم شده است. - اگر از طریق تونل SSH وصل میشوید، تأیید کنید تونل محلی بالا است و به پورت درست اشاره میکند.
- تأیید کنید فهرستهای مجاز شما (DM یا گروه) حساب شما را شامل میشوند.
مستندات: Tailscale، دسترسی از راه دور، کانالها.
آیا دو نمونهٔ OpenClaw میتوانند با هم صحبت کنند (محلی + VPS)؟
بله. پل داخلی «بات-به-بات» وجود ندارد، اما میتوانید آن را به چند روش قابلاعتماد وصل کنید:
سادهترین: از یک کانال گفتوگوی معمولی استفاده کنید که هر دو بات به آن دسترسی دارند (Telegram/Slack/WhatsApp). بگذارید Bot A پیامی به Bot B بفرستد، سپس Bot B طبق معمول پاسخ دهد.
پل CLI (عمومی): اسکریپتی اجرا کنید که Gateway دیگر را با
openclaw agent --message ... --deliver فراخوانی کند و گفتوگویی را هدف بگیرد که بات دیگر
در آن گوش میدهد. اگر یک بات روی VPS راه دور است، CLI خود را از طریق SSH/Tailscale به آن Gateway راه دور
اشاره دهید (دسترسی از راه دور را ببینید).
الگوی نمونه (از دستگاهی اجرا کنید که میتواند به Gateway هدف برسد):
openclaw agent --message "Hello from local bot" --deliver --channel telegram --reply-to <chat-id>نکته: یک محافظ اضافه کنید تا دو بات بیپایان وارد چرخه نشوند (فقط با منشن، فهرستهای مجاز کانال، یا قاعدهٔ «به پیامهای بات پاسخ نده»).
مستندات: دسترسی از راه دور، CLI عامل، ارسال عامل.
آیا برای چند عامل به VPSهای جداگانه نیاز دارم؟
نه. یک Gateway میتواند چند عامل را میزبانی کند، هرکدام با فضای کاری، پیشفرضهای مدل، و مسیریابی خودش. این راهاندازی معمول است و بسیار ارزانتر و سادهتر از اجرای یک VPS برای هر عامل است.
فقط وقتی به VPSهای جداگانه نیاز دارید که ایزولهسازی سخت (مرزهای امنیتی) یا پیکربندیهای بسیار متفاوت لازم دارید که نمیخواهید مشترک باشند. در غیر این صورت، یک Gateway نگه دارید و از چند عامل یا زیرعامل استفاده کنید.
آیا استفاده از نود روی لپتاپ شخصیام بهجای SSH از VPS مزیتی دارد؟
بله - نودها روش درجهاول برای دسترسی از یک Gateway راه دور به لپتاپ شما هستند، و چیزی فراتر از دسترسی شل فراهم میکنند. Gateway روی macOS/Linux (Windows از طریق WSL2) اجرا میشود و سبک است (یک VPS کوچک یا دستگاهی در حد Raspberry Pi کافی است؛ 4 GB RAM کاملاً کافی است)، بنابراین راهاندازی رایج یک میزبان همیشهروشن بههمراه لپتاپ شما بهعنوان نود است.
- SSH ورودی لازم نیست. نودها به Gateway WebSocket اتصال خروجی برقرار میکنند و از جفتسازی دستگاه استفاده میکنند.
- کنترلهای اجرای امنتر.
system.runبا فهرستهای مجاز/تأییدهای نود روی همان لپتاپ کنترل میشود. - ابزارهای دستگاه بیشتر. نودها افزون بر
system.run،canvas،camera، وscreenرا ارائه میکنند. - خودکارسازی مرورگر محلی. Gateway را روی VPS نگه دارید، اما Chrome را بهصورت محلی از طریق میزبان نود روی لپتاپ اجرا کنید، یا از طریق Chrome MCP به Chrome محلی روی میزبان متصل شوید.
SSH برای دسترسی موردی به شل مناسب است، اما نودها برای گردشکارهای مداوم عامل و خودکارسازی دستگاه سادهترند.
آیا نودها سرویس gateway اجرا میکنند؟
نه. فقط یک gateway باید روی هر میزبان اجرا شود، مگر اینکه عمداً پروفایلهای ایزوله اجرا کنید (چند Gateway را ببینید). نودها ابزارهای جانبی هستند که به gateway متصل میشوند (نودهای iOS/Android، یا «حالت نود» macOS در برنامهٔ menubar). برای میزبانهای نود headless و کنترل CLI، CLI میزبان نود را ببینید.
برای تغییرات سطح gateway، discovery، و Plugin میزبانیشده، راهاندازی مجدد کامل لازم است.
آیا راه API / RPC برای اعمال پیکربندی وجود دارد؟
بله.
config.schema.lookup: پیش از نوشتن، یک زیردرخت پیکربندی را همراه با گره schema سطحی، راهنمای UI منطبق، و خلاصههای فرزند بلافصل بررسی کنیدconfig.get: snapshot + hash فعلی را واکشی کنیدconfig.patch: بهروزرسانی جزئی امن (برای بیشتر ویرایشهای RPC ترجیح داده میشود)؛ هرجا ممکن باشد hot-reload میکند و هرجا لازم باشد راهاندازی مجدد میکندconfig.apply: اعتبارسنجی + جایگزینی کامل پیکربندی؛ هرجا ممکن باشد hot-reload میکند و هرجا لازم باشد راهاندازی مجدد میکند- ابزار runtime مالکمحور
gatewayهمچنان از بازنویسیtools.exec.ask/tools.exec.securityخودداری میکند؛ aliasهای قدیمیtools.bash.*به همان مسیرهای exec محافظتشده نرمالسازی میشوند
حداقل پیکربندی معقول برای نصب اول
{ agents: { defaults: { workspace: "~/.openclaw/workspace" } }, channels: { whatsapp: { allowFrom: ["+15555550123"] } },}این کار workspace شما را تنظیم میکند و محدود میکند چه کسی بتواند bot را فعال کند.
چگونه Tailscale را روی یک VPS راهاندازی کنم و از Mac خودم وصل شوم؟
مراحل حداقلی:
-
نصب + ورود روی VPS
bash curl -fsSL https://tailscale.com/install.sh | shsudo tailscale up -
نصب + ورود روی Mac
- از برنامه Tailscale استفاده کنید و وارد همان tailnet شوید.
-
فعالسازی MagicDNS (توصیهشده)
- در کنسول ادمین Tailscale، MagicDNS را فعال کنید تا VPS نامی پایدار داشته باشد.
-
استفاده از hostname مربوط به tailnet
- SSH:
ssh user@your-vps.tailnet-xxxx.ts.net - Gateway WS:
ws://your-vps.tailnet-xxxx.ts.net:18789
- SSH:
اگر Control UI را بدون SSH میخواهید، از Tailscale Serve روی VPS استفاده کنید:
openclaw gateway --tailscale serveاین کار gateway را متصل به loopback نگه میدارد و HTTPS را از طریق Tailscale در دسترس میگذارد. Tailscale را ببینید.
چگونه یک Node روی Mac را به یک Gateway راهدور وصل کنم (Tailscale Serve)؟
Serve، Gateway Control UI + WS را در دسترس میگذارد. Nodeها از طریق همان endpoint مربوط به Gateway WS وصل میشوند.
راهاندازی پیشنهادی:
-
مطمئن شوید VPS + Mac روی یک tailnet هستند.
-
از برنامه macOS در حالت Remote استفاده کنید (هدف SSH میتواند hostname مربوط به tailnet باشد). برنامه پورت Gateway را tunnel میکند و بهعنوان یک Node وصل میشود.
-
Node را روی gateway تأیید کنید:
bash openclaw devices listopenclaw devices approve <requestId>
مستندات: پروتکل Gateway، کشف، حالت راهدور macOS.
آیا باید روی یک لپتاپ دوم نصب کنم یا فقط یک Node اضافه کنم؟
اگر فقط به ابزارهای محلی (screen/camera/exec) روی لپتاپ دوم نیاز دارید، آن را بهعنوان یک Node اضافه کنید. این کار یک Gateway واحد را حفظ میکند و از پیکربندی تکراری جلوگیری میکند. ابزارهای Node محلی در حال حاضر فقط برای macOS هستند، اما قصد داریم آنها را به سیستمعاملهای دیگر هم گسترش دهیم.
فقط زمانی یک Gateway دوم نصب کنید که به جداسازی سختگیرانه یا دو bot کاملاً جدا نیاز دارید.
مستندات: Nodeها، CLI مربوط به Nodeها، چند Gateway.
متغیرهای محیطی و بارگذاری .env
OpenClaw چگونه متغیرهای محیطی را بارگذاری میکند؟
OpenClaw متغیرهای محیطی را از فرایند والد (shell، launchd/systemd، CI، و غیره) میخواند و علاوه بر آن موارد زیر را بارگذاری میکند:
.envاز دایرکتوری کاری فعلی- یک fallback سراسری
.envاز~/.openclaw/.env(یا همان$OPENCLAW_STATE_DIR/.env)
هیچکدام از فایلهای .env متغیرهای محیطی موجود را override نمیکنند.
همچنین میتوانید متغیرهای محیطی inline را در پیکربندی تعریف کنید (فقط اگر در process env وجود نداشته باشند اعمال میشوند):
{ env: { OPENROUTER_API_KEY: "sk-or-...", vars: { GROQ_API_KEY: "gsk-..." }, },}برای تقدم کامل و منابع، /environment را ببینید.
Gateway را از طریق سرویس شروع کردم و متغیرهای محیطیام ناپدید شدند. حالا چه کنم؟
دو راهحل رایج:
- کلیدهای گمشده را در
~/.openclaw/.envقرار دهید تا حتی وقتی سرویس env مربوط به shell شما را به ارث نمیبرد، دریافت شوند. - import از shell را فعال کنید (سهولت opt-in):
{ env: { shellEnv: { enabled: true, timeoutMs: 15000, }, },}این کار login shell شما را اجرا میکند و فقط کلیدهای مورد انتظارِ گمشده را import میکند (هرگز override نمیکند). معادلهای متغیر محیطی:
OPENCLAW_LOAD_SHELL_ENV=1, OPENCLAW_SHELL_ENV_TIMEOUT_MS=15000.
من COPILOT_GITHUB_TOKEN را تنظیم کردم، اما وضعیت مدلها "Shell env: off." نشان میدهد. چرا؟
openclaw models status گزارش میدهد که آیا import از shell env فعال است یا نه. "Shell env: off"
به این معنی نیست که متغیرهای محیطی شما گم شدهاند - فقط یعنی OpenClaw بهطور خودکار
login shell شما را بارگذاری نمیکند.
اگر Gateway بهعنوان سرویس (launchd/systemd) اجرا شود، environment مربوط به shell شما را به ارث نمیبرد. با انجام یکی از این کارها اصلاحش کنید:
-
token را در
~/.openclaw/.envقرار دهید:Code COPILOT_GITHUB_TOKEN=... -
یا import از shell را فعال کنید (
env.shellEnv.enabled: true). -
یا آن را به بلوک
envدر پیکربندی خود اضافه کنید (فقط اگر موجود نباشد اعمال میشود).
سپس gateway را راهاندازی مجدد کنید و دوباره بررسی کنید:
openclaw models statustokenهای Copilot از COPILOT_GITHUB_TOKEN (همچنین GH_TOKEN / GITHUB_TOKEN) خوانده میشوند.
/concepts/model-providers و /environment را ببینید.
نشستها و چند chat
چگونه یک گفتوگوی تازه شروع کنم؟
/new یا /reset را بهعنوان یک پیام مستقل بفرستید. مدیریت نشست را ببینید.
اگر هرگز /new نفرستم، آیا نشستها خودکار reset میشوند؟
نشستها میتوانند پس از session.idleMinutes منقضی شوند، اما این قابلیت بهطور پیشفرض غیرفعال است (پیشفرض 0).
برای فعالسازی انقضای بیکاری، آن را روی یک مقدار مثبت تنظیم کنید. وقتی فعال باشد، پیام بعدی
پس از دوره بیکاری، یک session id تازه برای همان chat key شروع میکند.
این کار transcriptها را حذف نمیکند - فقط یک نشست جدید شروع میکند.
{ session: { idleMinutes: 240, },}آیا راهی هست که یک تیم از instanceهای OpenClaw بسازم (یک CEO و تعداد زیادی عامل)؟
بله، از طریق مسیریابی چندعاملی و عاملهای فرعی. میتوانید یک عامل هماهنگکننده و چند عامل worker با workspaceها و مدلهای خودشان بسازید.
با این حال، بهتر است این را یک آزمایش سرگرمکننده ببینید. مصرف token آن زیاد است و اغلب از استفاده از یک bot با نشستهای جداگانه کمبازدهتر است. مدل معمولی که تصور میکنیم یک bot است که با آن صحبت میکنید، با نشستهای مختلف برای کار موازی. آن bot همچنین میتواند در صورت نیاز عاملهای فرعی ایجاد کند.
مستندات: مسیریابی چندعاملی، عاملهای فرعی، CLI عاملها.
چرا context در میانه کار truncate شد؟ چگونه از آن جلوگیری کنم؟
context نشست به window مدل محدود است. chatهای طولانی، خروجیهای بزرگ ابزارها، یا فایلهای زیاد میتوانند باعث Compaction یا truncation شوند.
چیزهایی که کمک میکنند:
- از bot بخواهید وضعیت فعلی را خلاصه کند و در یک فایل بنویسد.
- پیش از کارهای طولانی از
/compactاستفاده کنید، و هنگام تغییر موضوع از/new. - context مهم را در workspace نگه دارید و از bot بخواهید دوباره آن را بخواند.
- برای کارهای طولانی یا موازی از عاملهای فرعی استفاده کنید تا chat اصلی کوچکتر بماند.
- اگر این اتفاق زیاد میافتد، مدلی با window بزرگتر برای context انتخاب کنید.
چگونه OpenClaw را کامل reset کنم اما نصبشده نگه دارم؟
از دستور reset استفاده کنید:
openclaw resetreset کامل غیرتعاملی:
openclaw reset --scope full --yes --non-interactiveسپس setup را دوباره اجرا کنید:
openclaw onboard --install-daemonنکات:
- اگر onboarding یک پیکربندی موجود ببیند، Reset را هم پیشنهاد میدهد. Onboarding (CLI) را ببینید.
- اگر از profileها (
--profile/OPENCLAW_PROFILE) استفاده کردهاید، هر state dir را reset کنید (پیشفرضها~/.openclaw-<profile>هستند). - reset مخصوص dev:
openclaw gateway --dev --reset(فقط dev؛ پیکربندی dev + credentials + نشستها + workspace را پاک میکند).
خطاهای "context too large" میگیرم - چگونه reset یا compact کنم؟
از یکی از اینها استفاده کنید:
-
Compact (گفتوگو را نگه میدارد اما turnهای قدیمیتر را خلاصه میکند):
Code /compactیا
/compact <instructions>برای هدایت خلاصه. -
Reset (session ID تازه برای همان chat key):
Code /new/reset
اگر همچنان رخ میدهد:
- هرس نشست (
agents.defaults.contextPruning) را فعال یا تنظیم کنید تا خروجی ابزارهای قدیمی trim شود. - از مدلی با window بزرگتر برای context استفاده کنید.
مستندات: Compaction، هرس نشست، مدیریت نشست.
چرا "LLM request rejected: messages.content.tool_use.input field required" را میبینم؟
این یک خطای اعتبارسنجی provider است: مدل یک بلوک tool_use بدون input موردنیاز
تولید کرده است. معمولاً یعنی تاریخچه نشست stale یا خراب شده است (اغلب پس از threadهای طولانی
یا تغییر ابزار/schema).
رفع: یک نشست تازه با /new شروع کنید (پیام مستقل).
چرا هر ۳۰ دقیقه پیامهای heartbeat میگیرم؟
Heartbeatها بهطور پیشفرض هر 30m اجرا میشوند (1h هنگام استفاده از OAuth auth). آنها را تنظیم یا غیرفعال کنید:
{ agents: { defaults: { heartbeat: { every: "2h", // or "0m" to disable }, }, },}اگر HEARTBEAT.md وجود داشته باشد اما عملاً خالی باشد (فقط خطوط خالی و headerهای markdown
مثل # Heading)، OpenClaw اجرای Heartbeat را برای صرفهجویی در API callها رد میکند.
اگر فایل وجود نداشته باشد، Heartbeat همچنان اجرا میشود و مدل تصمیم میگیرد چه کند.
overrideهای هر عامل از agents.list[].heartbeat استفاده میکنند. مستندات: Heartbeat.
آیا باید یک "bot account" به یک گروه WhatsApp اضافه کنم؟
نه. OpenClaw روی حساب خود شما اجرا میشود، بنابراین اگر شما در گروه باشید، OpenClaw میتواند آن را ببیند.
بهطور پیشفرض، پاسخهای گروهی تا وقتی فرستندهها را مجاز نکنید مسدود هستند (groupPolicy: "allowlist").
اگر میخواهید فقط خودتان بتوانید پاسخهای گروهی را فعال کنید:
{ channels: { whatsapp: { groupPolicy: "allowlist", groupAllowFrom: ["+15551234567"], }, },}چگونه JID یک گروه WhatsApp را به دست بیاورم؟
گزینه ۱ (سریعترین): logها را tail کنید و یک پیام آزمایشی در گروه بفرستید:
openclaw logs --follow --jsonدنبال chatId (یا from) بگردید که به @g.us ختم میشود، مثل:
1234567890-1234567890@g.us.
گزینه ۲ (اگر از قبل پیکربندی/allowlist شده است): گروهها را از پیکربندی فهرست کنید:
openclaw directory groups list --channel whatsappچرا OpenClaw در یک گروه پاسخ نمیدهد؟
دو علت رایج:
- mention gating روشن است (پیشفرض). باید bot را @mention کنید (یا با
mentionPatternsمطابقت داشته باشد). - شما
channels.whatsapp.groupsرا بدون"*"پیکربندی کردهاید و گروه در allowlist نیست.
گروهها و پیامهای گروهی را ببینید.
آیا گروهها/threadها با DMها context مشترک دارند؟
chatهای مستقیم بهطور پیشفرض به نشست اصلی collapse میشوند. گروهها/channelها کلیدهای نشست خودشان را دارند، و topicهای Telegram / threadهای Discord نشستهای جداگانه هستند. گروهها و پیامهای گروهی را ببینید.
چند فضای کاری و عامل میتوانم ایجاد کنم؟
محدودیت سختی وجود ندارد. دهها مورد (حتی صدها مورد) مشکلی ندارد، اما مراقب این موارد باشید:
- رشد دیسک: نشستها + رونوشتها زیر
~/.openclaw/agents/<agentId>/sessions/قرار دارند. - هزینه توکن: عاملهای بیشتر یعنی استفاده همزمان بیشتر از مدل.
- سربار عملیات: پروفایلهای احراز هویت، فضاهای کاری، و مسیریابی کانال برای هر عامل.
نکتهها:
- برای هر عامل یک فضای کاری فعال نگه دارید (
agents.defaults.workspace). - اگر دیسک رشد کرد، نشستهای قدیمی را پاک کنید (حذف JSONL یا ورودیهای ذخیره).
- برای پیدا کردن فضاهای کاری سرگردان و ناسازگاریهای پروفایل از
openclaw doctorاستفاده کنید.
آیا میتوانم چند ربات یا چت را همزمان اجرا کنم (Slack)، و چگونه باید آن را تنظیم کنم؟
بله. از مسیریابی چندعاملی برای اجرای چند عامل ایزوله و مسیریابی پیامهای ورودی بر اساس کانال/حساب/همتا استفاده کنید. Slack بهعنوان یک کانال پشتیبانی میشود و میتواند به عاملهای مشخص متصل شود.
دسترسی مرورگر قدرتمند است، اما به معنی «انجام هر کاری که انسان میتواند» نیست - ضدربات، CAPTCHA، و MFA همچنان میتوانند خودکارسازی را مسدود کنند. برای قابلاعتمادترین کنترل مرورگر، از Chrome MCP محلی روی میزبان استفاده کنید، یا از CDP روی ماشینی استفاده کنید که واقعا مرورگر را اجرا میکند.
تنظیم پیشنهادی:
- میزبان Gateway همیشه روشن (VPS/Mac mini).
- یک عامل برای هر نقش (اتصالها).
- کانال(های) Slack متصل به آن عاملها.
- مرورگر محلی از طریق Chrome MCP یا یک Node در صورت نیاز.
مستندات: مسیریابی چندعاملی، Slack، مرورگر، Nodeها.
مدلها، تغییرمسیر هنگام خرابی، و پروفایلهای احراز هویت
پرسشوپاسخ مدل — پیشفرضها، انتخاب، نامهای مستعار، جابهجایی، تغییرمسیر هنگام خرابی، پروفایلهای احراز هویت — در پرسشهای متداول مدلها قرار دارد.
Gateway: پورتها، «در حال اجراست»، و حالت راه دور
Gateway از چه پورتی استفاده میکند؟
gateway.port پورت چندمنظوره واحد برای WebSocket + HTTP را کنترل میکند (رابط کنترل، hookها، و غیره).
ترتیب اولویت:
--port > OPENCLAW_GATEWAY_PORT > gateway.port > default 18789چرا openclaw gateway status میگوید "Runtime: running" اما "Connectivity probe: failed"؟
چون «در حال اجرا» دید ناظر است (launchd/systemd/schtasks). آزمون اتصال یعنی CLI واقعا در حال اتصال به WebSocket مربوط به Gateway است.
از openclaw gateway status استفاده کنید و به این خطها اعتماد کنید:
Probe target:(نشانی URL که آزمون واقعا استفاده کرده است)Listening:(چیزی که واقعا روی پورت bind شده است)Last gateway error:(علت ریشهای رایج وقتی فرایند زنده است اما پورت گوش نمیدهد)
چرا openclaw gateway status مقدارهای متفاوتی برای "Config (cli)" و "Config (service)" نشان میدهد؟
شما در حال ویرایش یک فایل پیکربندی هستید، در حالی که سرویس پیکربندی دیگری را اجرا میکند (اغلب ناسازگاری --profile / OPENCLAW_STATE_DIR).
رفع مشکل:
openclaw gateway install --forceآن را از همان --profile / محیطی اجرا کنید که میخواهید سرویس استفاده کند.
عبارت "another gateway instance is already listening" یعنی چه؟
OpenClaw با bind کردن شنونده WebSocket بلافاصله هنگام راهاندازی، یک قفل زمان اجرا اعمال میکند (پیشفرض ws://127.0.0.1:18789). اگر bind با EADDRINUSE شکست بخورد، خطای GatewayLockError میدهد که نشان میدهد نمونه دیگری در حال گوش دادن است.
رفع مشکل: نمونه دیگر را متوقف کنید، پورت را آزاد کنید، یا با openclaw gateway --port <port> اجرا کنید.
چگونه OpenClaw را در حالت راه دور اجرا کنم (کلاینت به Gateway در جای دیگری وصل شود)؟
gateway.mode: "remote" را تنظیم کنید و به یک URL راه دور WebSocket اشاره کنید، در صورت نیاز همراه با اعتبارنامههای راه دور با secret مشترک:
{ gateway: { mode: "remote", remote: { url: "ws://gateway.tailnet:18789", token: "your-token", password: "your-password", }, },}یادداشتها:
openclaw gatewayفقط وقتی شروع میشود کهgateway.modeبرابرlocalباشد (یا فلگ override را پاس کنید).- برنامه macOS فایل پیکربندی را پایش میکند و با تغییر این مقدارها، بهصورت زنده حالتها را عوض میکند.
gateway.remote.token/.passwordفقط اعتبارنامههای راه دور سمت کلاینت هستند؛ بهتنهایی احراز هویت Gateway محلی را فعال نمیکنند.
رابط کنترل میگوید "unauthorized" (یا مدام دوباره وصل میشود). حالا چه کار کنم؟
مسیر احراز هویت Gateway شما با روش احراز هویت رابط کاربری مطابقت ندارد.
واقعیتها (از کد):
- رابط کنترل توکن را برای نشست تب فعلی مرورگر و URL انتخابشده Gateway در
sessionStorageنگه میدارد، بنابراین تازهسازیهای همان تب بدون بازگردانی تداوم توکن طولانیمدت در localStorage همچنان کار میکنند. - هنگام
AUTH_TOKEN_MISMATCH، کلاینتهای قابلاعتماد میتوانند وقتی Gateway راهنماییهای تلاش دوباره را برمیگرداند (canRetryWithDeviceToken=true,recommendedNextStep=retry_with_device_token)، یک تلاش دوباره محدود با توکن دستگاه کششده انجام دهند. - آن تلاش دوباره با توکن کششده اکنون از همان scopeهای تاییدشده کششده که همراه توکن دستگاه ذخیره شدهاند دوباره استفاده میکند. فراخوانهای دارای
deviceTokenصریح /scopesصریح همچنان بهجای ارثبری از scopeهای کششده، مجموعه scope درخواستی خود را نگه میدارند. - خارج از آن مسیر تلاش دوباره، اولویت احراز هویت اتصال ابتدا توکن/رمز عبور مشترک صریح است، سپس
deviceTokenصریح، سپس توکن دستگاه ذخیرهشده، و سپس توکن bootstrap. - بررسیهای scope توکن bootstrap با پیشوند نقش انجام میشوند. فهرست مجاز اپراتور bootstrap داخلی فقط درخواستهای اپراتور را برآورده میکند؛ Node یا نقشهای غیر اپراتور دیگر همچنان به scopeهایی زیر پیشوند نقش خودشان نیاز دارند.
رفع مشکل:
- سریعترین راه:
openclaw dashboard(URL داشبورد را چاپ + کپی میکند، تلاش میکند باز کند؛ اگر headless باشد راهنمای SSH نشان میدهد). - اگر هنوز توکن ندارید:
openclaw doctor --generate-gateway-token. - اگر راه دور است، ابتدا تونل بزنید:
ssh -N -L 18789:127.0.0.1:18789 user@hostسپسhttp://127.0.0.1:18789/را باز کنید. - حالت secret مشترک:
gateway.auth.token/OPENCLAW_GATEWAY_TOKENیاgateway.auth.password/OPENCLAW_GATEWAY_PASSWORDرا تنظیم کنید، سپس secret مطابق را در تنظیمات رابط کنترل جایگذاری کنید. - حالت Tailscale Serve: مطمئن شوید
gateway.auth.allowTailscaleفعال است و URL مربوط به Serve را باز میکنید، نه یک URL خام loopback/tailnet که هدرهای هویت Tailscale را دور میزند. - حالت پراکسی قابلاعتماد: مطمئن شوید از مسیر پراکسی آگاه از هویت پیکربندیشده وارد میشوید، نه یک URL خام Gateway. پراکسیهای loopback روی همان میزبان نیز به
gateway.auth.trustedProxy.allowLoopback = trueنیاز دارند. - اگر ناسازگاری پس از یک تلاش دوباره ادامه داشت، توکن دستگاه جفتشده را بچرخانید/دوباره تایید کنید:
openclaw devices listopenclaw devices rotate --device <id> --role operator
- اگر آن فراخوان rotate گفت رد شده است، دو مورد را بررسی کنید:
- نشستهای دستگاه جفتشده فقط میتوانند دستگاه خودشان را بچرخانند، مگر اینکه
operator.adminهم داشته باشند - مقدارهای صریح
--scopeنمیتوانند از scopeهای فعلی اپراتورِ فراخواننده فراتر بروند
- نشستهای دستگاه جفتشده فقط میتوانند دستگاه خودشان را بچرخانند، مگر اینکه
- هنوز گیر کردهاید؟
openclaw status --allرا اجرا کنید و عیبیابی را دنبال کنید. برای جزئیات احراز هویت، داشبورد را ببینید.
gateway.bind را روی tailnet تنظیم کردم اما نمیتواند bind کند و چیزی گوش نمیدهد
bind با tailnet یک IP مربوط به Tailscale را از رابطهای شبکه شما انتخاب میکند (100.64.0.0/10). اگر ماشین روی Tailscale نباشد (یا رابط غیرفعال باشد)، چیزی برای bind کردن وجود ندارد.
رفع مشکل:
- Tailscale را روی آن میزبان شروع کنید (تا یک نشانی 100.x داشته باشد)، یا
- به
gateway.bind: "loopback"/"lan"تغییر دهید.
نکته: tailnet صریح است. auto loopback را ترجیح میدهد؛ وقتی bind فقط برای tailnet میخواهید، از gateway.bind: "tailnet" استفاده کنید.
آیا میتوانم چند Gateway را روی یک میزبان اجرا کنم؟
معمولا نه - یک Gateway میتواند چند کانال پیامرسانی و عامل را اجرا کند. فقط وقتی از چند Gateway استفاده کنید که به افزونگی (مثلا ربات نجات) یا ایزولاسیون سخت نیاز دارید.
بله، اما باید ایزوله کنید:
OPENCLAW_CONFIG_PATH(پیکربندی برای هر نمونه)OPENCLAW_STATE_DIR(وضعیت برای هر نمونه)agents.defaults.workspace(ایزولاسیون فضای کاری)gateway.port(پورتهای یکتا)
تنظیم سریع (پیشنهادی):
- برای هر نمونه از
openclaw --profile <name> ...استفاده کنید (بهصورت خودکار~/.openclaw-<name>را ایجاد میکند). - در پیکربندی هر پروفایل یک
gateway.portیکتا تنظیم کنید (یا برای اجراهای دستی--portرا پاس کنید). - سرویس هر پروفایل را نصب کنید:
openclaw --profile <name> gateway install.
پروفایلها همچنین پسوندی به نام سرویس اضافه میکنند (ai.openclaw.<profile>؛ قدیمی: com.openclaw.*, openclaw-gateway-<profile>.service, OpenClaw Gateway (<profile>)).
راهنمای کامل: چند Gateway.
عبارت "invalid handshake" / کد 1008 یعنی چه؟
Gateway یک سرور WebSocket است و انتظار دارد اولین پیام
یک فریم connect باشد. اگر هر چیز دیگری دریافت کند، اتصال را
با کد 1008 (نقض سیاست) میبندد.
علتهای رایج:
- URL مربوط به HTTP را در مرورگر باز کردهاید (
http://...) بهجای یک کلاینت WS. - از پورت یا مسیر اشتباه استفاده کردهاید.
- یک پراکسی یا تونل هدرهای احراز هویت را حذف کرده یا یک درخواست غیر Gateway فرستاده است.
رفع سریع:
- از URL مربوط به WS استفاده کنید:
ws://<host>:18789(یا اگر HTTPS استwss://...). - پورت WS را در یک تب معمولی مرورگر باز نکنید.
- اگر احراز هویت فعال است، توکن/رمز عبور را در فریم
connectوارد کنید.
اگر از CLI یا TUI استفاده میکنید، URL باید شبیه این باشد:
openclaw tui --url ws://<host>:18789 --token <token>جزئیات پروتکل: پروتکل Gateway.
لاگبرداری و اشکالزدایی
لاگها کجا هستند؟
لاگهای فایل (ساختاریافته):
/tmp/openclaw/openclaw-YYYY-MM-DD.logمیتوانید از طریق logging.file یک مسیر پایدار تنظیم کنید. سطح لاگ فایل با logging.level کنترل میشود. پرگویی کنسول با --verbose و logging.consoleLevel کنترل میشود.
سریعترین دنبال کردن لاگ:
openclaw logs --followلاگهای سرویس/ناظر (وقتی Gateway از طریق launchd/systemd اجرا میشود):
- macOS:
$OPENCLAW_STATE_DIR/logs/gateway.logوgateway.err.log(پیشفرض:~/.openclaw/logs/...؛ پروفایلها از~/.openclaw-<profile>/logs/...استفاده میکنند) - Linux:
journalctl --user -u openclaw-gateway[-<profile>].service -n 200 --no-pager - Windows:
schtasks /Query /TN "OpenClaw Gateway (<profile>)" /V /FO LIST
برای اطلاعات بیشتر عیبیابی را ببینید.
چگونه سرویس Gateway را شروع/متوقف/بازراهاندازی کنم؟
از helperهای Gateway استفاده کنید:
openclaw gateway statusopenclaw gateway restartاگر Gateway را دستی اجرا میکنید، openclaw gateway --force میتواند پورت را بازپس بگیرد. Gateway را ببینید.
ترمینالم را در Windows بستم - چگونه OpenClaw را بازراهاندازی کنم؟
دو حالت نصب Windows وجود دارد:
1) WSL2 (پیشنهادی): Gateway داخل Linux اجرا میشود.
PowerShell را باز کنید، وارد WSL شوید، سپس بازراهاندازی کنید:
wslopenclaw gateway statusopenclaw gateway restartاگر هرگز سرویس را نصب نکردهاید، آن را در foreground شروع کنید:
openclaw gateway run2) Windows بومی (پیشنهاد نمیشود): Gateway مستقیما در Windows اجرا میشود.
PowerShell را باز کنید و اجرا کنید:
openclaw gateway statusopenclaw gateway restartاگر آن را دستی اجرا میکنید (بدون سرویس)، استفاده کنید:
openclaw gateway runمستندات: Windows (WSL2)، راهنمای اجرایی سرویس Gateway.
Gateway بالا است اما پاسخها هرگز نمیرسند. چه چیزی را باید بررسی کنم؟
با یک بررسی سلامت سریع شروع کنید:
openclaw statusopenclaw models statusopenclaw channels statusopenclaw logs --followعلتهای رایج:
- احراز هویت مدل روی میزبان Gateway بارگذاری نشده است (
models statusرا بررسی کنید). - جفتسازی کانال/allowlist پاسخها را مسدود میکند (پیکربندی کانال + لاگها را بررسی کنید).
- WebChat/Dashboard بدون توکن درست باز است.
اگر از راه دور هستید، تأیید کنید اتصال تونل/Tailscale برقرار است و WebSocket مربوط به Gateway در دسترس است.
مستندات: کانالها، عیبیابی، دسترسی راه دور.
"ارتباط با gateway قطع شد: بدون دلیل" - حالا چه؟
این معمولاً یعنی UI اتصال WebSocket را از دست داده است. بررسی کنید:
- آیا Gateway در حال اجراست؟
openclaw gateway status - آیا Gateway سالم است؟
openclaw status - آیا UI توکن درست را دارد؟
openclaw dashboard - اگر از راه دور هستید، آیا لینک تونل/Tailscale برقرار است؟
سپس لاگها را دنبال کنید:
openclaw logs --followمستندات: Dashboard، دسترسی راه دور، عیبیابی.
Telegram setMyCommands ناموفق میشود. چه چیزی را باید بررسی کنم؟
با لاگها و وضعیت کانال شروع کنید:
openclaw channels statusopenclaw channels logs --channel telegramسپس خطا را تطبیق دهید:
BOT_COMMANDS_TOO_MUCH: منوی Telegram ورودیهای بیش از حدی دارد. OpenClaw از قبل تعداد را تا سقف Telegram کم میکند و با فرمانهای کمتر دوباره تلاش میکند، اما هنوز باید برخی ورودیهای منو حذف شوند. فرمانهای Plugin/skill/سفارشی را کاهش دهید، یا اگر به منو نیاز نداریدchannels.telegram.commands.nativeرا غیرفعال کنید.TypeError: fetch failed،Network request for 'setMyCommands' failed!، یا خطاهای شبکه مشابه: اگر روی VPS هستید یا پشت پروکسی قرار دارید، تأیید کنید HTTPS خروجی مجاز است و DNS برایapi.telegram.orgکار میکند.
اگر Gateway از راه دور است، مطمئن شوید لاگها را روی میزبان Gateway میبینید.
مستندات: Telegram، عیبیابی کانال.
TUI خروجی نشان نمیدهد. چه چیزی را باید بررسی کنم؟
ابتدا تأیید کنید Gateway در دسترس است و عامل میتواند اجرا شود:
openclaw statusopenclaw models statusopenclaw logs --followدر TUI، از /status برای دیدن وضعیت فعلی استفاده کنید. اگر انتظار پاسخ در یک
کانال چت را دارید، مطمئن شوید ارسال فعال است (/deliver on).
مستندات: TUI، فرمانهای اسلش.
چطور Gateway را کاملاً متوقف و سپس شروع کنم؟
اگر سرویس را نصب کردهاید:
openclaw gateway stopopenclaw gateway startاین کار سرویس تحت نظارت را متوقف/شروع میکند (launchd روی macOS، systemd روی Linux). وقتی Gateway بهصورت daemon در پسزمینه اجرا میشود از این استفاده کنید.
اگر در پیشزمینه اجرا میکنید، با Ctrl-C متوقف کنید، سپس:
openclaw gateway runمستندات: راهنمای عملیاتی سرویس Gateway.
توضیح ساده: openclaw gateway restart در برابر openclaw gateway
openclaw gateway restart: سرویس پسزمینه را دوباره راهاندازی میکند (launchd/systemd).openclaw gateway: gateway را برای همین نشست ترمینال در پیشزمینه اجرا میکند.
اگر سرویس را نصب کردهاید، از فرمانهای gateway استفاده کنید. وقتی
یک اجرای یکباره و پیشزمینه میخواهید، از openclaw gateway استفاده کنید.
سریعترین راه برای گرفتن جزئیات بیشتر وقتی چیزی ناموفق میشود
Gateway را با --verbose شروع کنید تا جزئیات بیشتری در کنسول بگیرید. سپس فایل لاگ را برای احراز هویت کانال، مسیریابی مدل، و خطاهای RPC بررسی کنید.
رسانه و پیوستها
Skill من یک تصویر/PDF تولید کرد، اما چیزی ارسال نشد
پیوستهای خروجی از عامل باید یک خط MEDIA:<path-or-url> داشته باشند (در خط جداگانه). راهاندازی دستیار OpenClaw و ارسال عامل را ببینید.
ارسال با CLI:
openclaw message send --target +15555550123 --message "Here you go" --media /path/to/file.pngهمچنین بررسی کنید:
- کانال مقصد از رسانه خروجی پشتیبانی میکند و توسط allowlist مسدود نشده است.
- فایل در محدوده اندازه ارائهدهنده باشد (اندازه تصاویر تا حداکثر 2048px تغییر داده میشود).
tools.fs.workspaceOnly=trueارسالهای مسیر محلی را به workspace، temp/media-store، و فایلهای تأییدشده توسط sandbox محدود نگه میدارد.tools.fs.workspaceOnly=falseاجازه میدهدMEDIA:فایلهای محلی میزبان را که عامل از قبل میتواند بخواند ارسال کند، اما فقط برای رسانه و انواع سند امن (تصویر، صدا، ویدئو، PDF، و اسناد Office). فایلهای متن ساده و شبیه به secret همچنان مسدود میشوند.
تصاویر را ببینید.
امنیت و کنترل دسترسی
آیا در معرض قرار دادن OpenClaw برای DMهای ورودی امن است؟
DMهای ورودی را ورودی غیرقابل اعتماد در نظر بگیرید. پیشفرضها برای کاهش ریسک طراحی شدهاند:
- رفتار پیشفرض در کانالهایی که از DM پشتیبانی میکنند جفتسازی است:
- فرستندههای ناشناس یک کد جفتسازی دریافت میکنند؛ بات پیام آنها را پردازش نمیکند.
- با این فرمان تأیید کنید:
openclaw pairing approve --channel <channel> [--account <id>] <code> - درخواستهای در انتظار به 3 مورد برای هر کانال محدود میشوند؛ اگر کدی نرسید،
openclaw pairing list --channel <channel> [--account <id>]را بررسی کنید.
- عمومی کردن DMها نیازمند فعالسازی صریح است (
dmPolicy: "open"و allowlist"*").
برای آشکار کردن سیاستهای پرریسک DM، openclaw doctor را اجرا کنید.
آیا prompt injection فقط برای باتهای عمومی مسئله است؟
خیر. prompt injection مربوط به محتوای غیرقابل اعتماد است، نه فقط اینکه چه کسی میتواند به بات DM بدهد. اگر دستیار شما محتوای خارجی را میخواند (جستوجو/دریافت وب، صفحههای مرورگر، ایمیلها، مستندات، پیوستها، لاگهای چسباندهشده)، آن محتوا میتواند شامل دستورهایی باشد که تلاش میکنند مدل را به کنترل خود درآورند. این حتی اگر شما تنها فرستنده باشید هم ممکن است رخ دهد.
بزرگترین ریسک وقتی است که ابزارها فعال هستند: مدل میتواند فریب بخورد تا زمینه را استخراج کند یا ابزارها را از طرف شما فراخوانی کند. دامنه آسیب را اینطور کاهش دهید:
- استفاده از یک عامل «reader» فقطخواندنی یا بدون ابزار برای خلاصهسازی محتوای غیرقابل اعتماد
- خاموش نگه داشتن
web_search/web_fetch/browserبرای عاملهای دارای ابزار - در نظر گرفتن متن استخراجشده از فایل/سند بهعنوان غیرقابل اعتماد: OpenResponses
input_fileو استخراج پیوست رسانه هر دو متن استخراجشده را بهجای عبور دادن متن خام فایل، در نشانگرهای صریح مرز محتوای خارجی میپیچند - sandbox کردن و allowlistهای سختگیرانه ابزارها
جزئیات: امنیت.
آیا بات من باید ایمیل، حساب GitHub، یا شماره تلفن خودش را داشته باشد؟
بله، برای بیشتر راهاندازیها. جدا کردن بات با حسابها و شمارههای تلفن مستقل در صورت بروز مشکل دامنه آسیب را کاهش میدهد. این کار همچنین چرخاندن اعتبارنامهها یا لغو دسترسی را بدون اثر روی حسابهای شخصی شما آسانتر میکند.
کوچک شروع کنید. فقط به ابزارها و حسابهایی که واقعاً نیاز دارید دسترسی بدهید، و در صورت نیاز بعداً گسترش دهید.
آیا میتوانم به آن اختیار پیامهای متنیام را بدهم و آیا این امن است؟
ما اختیار کامل روی پیامهای شخصی شما را توصیه نمیکنیم. امنترین الگو این است:
- DMها را در حالت جفتسازی یا یک allowlist محدود نگه دارید.
- اگر میخواهید از طرف شما پیام بدهد، از یک شماره یا حساب جداگانه استفاده کنید.
- اجازه دهید پیشنویس کند، سپس پیش از ارسال تأیید کنید.
اگر میخواهید آزمایش کنید، این کار را روی یک حساب اختصاصی انجام دهید و آن را جدا نگه دارید. ببینید امنیت.
آیا میتوانم برای کارهای دستیار شخصی از مدلهای ارزانتر استفاده کنم؟
بله، اگر عامل فقط برای چت باشد و ورودی قابل اعتماد باشد. ردههای کوچکتر نسبت به ربودن دستورپذیری حساسترند، بنابراین برای عاملهای دارای ابزار یا هنگام خواندن محتوای غیرقابل اعتماد از آنها اجتناب کنید. اگر مجبورید از مدل کوچکتر استفاده کنید، ابزارها را قفل کنید و داخل sandbox اجرا کنید. امنیت را ببینید.
در Telegram /start را اجرا کردم اما کد جفتسازی نگرفتم
کدهای جفتسازی فقط وقتی ارسال میشوند که یک فرستنده ناشناس به بات پیام بدهد و
dmPolicy: "pairing" فعال باشد. /start بهتنهایی کد تولید نمیکند.
درخواستهای در انتظار را بررسی کنید:
openclaw pairing list telegramاگر دسترسی فوری میخواهید، شناسه فرستنده خود را در allowlist بگذارید یا dmPolicy: "open"
را برای آن حساب تنظیم کنید.
WhatsApp: آیا به مخاطبان من پیام میدهد؟ جفتسازی چگونه کار میکند؟
خیر. سیاست پیشفرض DM در WhatsApp جفتسازی است. فرستندههای ناشناس فقط یک کد جفتسازی دریافت میکنند و پیام آنها پردازش نمیشود. OpenClaw فقط به چتهایی پاسخ میدهد که دریافت میکند یا به ارسالهای صریحی که شما فعال میکنید.
جفتسازی را با این فرمان تأیید کنید:
openclaw pairing approve whatsapp <code>درخواستهای در انتظار را فهرست کنید:
openclaw pairing list whatsappدرخواست شماره تلفن در wizard: از آن برای تنظیم allowlist/owner شما استفاده میشود تا DMهای خودتان مجاز باشند. برای ارسال خودکار استفاده نمیشود. اگر روی شماره WhatsApp شخصی خود اجرا میکنید، از همان شماره استفاده کنید و channels.whatsapp.selfChatMode را فعال کنید.
فرمانهای چت، متوقف کردن کارها، و «متوقف نمیشود»
چطور جلوی نمایش پیامهای داخلی سیستم در چت را بگیرم؟
بیشتر پیامهای داخلی یا ابزار فقط وقتی ظاهر میشوند که verbose، trace، یا reasoning برای آن نشست فعال باشد.
در همان چتی که آن را میبینید اصلاح کنید:
/verbose off/trace off/reasoning offاگر هنوز پر سروصداست، تنظیمات نشست را در Control UI بررسی کنید و verbose
را روی inherit بگذارید. همچنین تأیید کنید از پروفایل باتی استفاده نمیکنید که verboseDefault در پیکربندی
روی on تنظیم شده باشد.
مستندات: تفکر و verbose، امنیت.
چطور یک کار در حال اجرا را متوقف/لغو کنم؟
هرکدام از اینها را بهعنوان یک پیام مستقل بفرستید (بدون اسلش):
stopstop actionstop current actionstop runstop current runstop agentstop the agentstop openclawopenclaw stopstop don't do anythingstop do not do anythingstop doing anythingplease stopstop pleaseabortescwaitexitinterruptاینها محرکهای لغو هستند (نه فرمانهای اسلش).
برای پردازههای پسزمینه (از ابزار exec)، میتوانید از عامل بخواهید اجرا کند:
process action:kill sessionId:XXXمرور کلی فرمانهای اسلش: فرمانهای اسلش را ببینید.
بیشتر فرمانها باید بهعنوان یک پیام مستقل که با / شروع میشود ارسال شوند، اما چند میانبر (مثل /status) برای فرستندههای موجود در allowlist بهصورت inline هم کار میکنند.
چطور از Telegram پیام Discord بفرستم؟ ("پیامرسانی میانزمینهای رد شد")
OpenClaw بهطور پیشفرض پیامرسانی میان ارائهدهندهها را مسدود میکند. اگر یک فراخوانی ابزار به Telegram متصل باشد، به Discord ارسال نمیکند مگر اینکه صراحتاً اجازه دهید.
پیامرسانی میان ارائهدهندهها را برای عامل فعال کنید:
{ tools: { message: { crossContext: { allowAcrossProviders: true, marker: { enabled: true, prefix: "[from {channel}] " }, }, }, },}پس از ویرایش پیکربندی، gateway را دوباره راهاندازی کنید.
چرا حس میشود بات پیامهای سریع و پشتسرهم را "نادیده میگیرد"؟
حالت صف کنترل میکند پیامهای جدید چطور با یک اجرای در جریان تعامل کنند. برای تغییر حالتها از /queue استفاده کنید:
steer- همه هدایتهای در انتظار را برای مرز مدل بعدی در اجرای فعلی صف میکندqueue- هدایت قدیمی یکییکیfollowup- پیامها را یکییکی اجرا میکندcollect- پیامها را دستهبندی میکند و یکبار پاسخ میدهدsteer-backlog- اکنون هدایت میکند، سپس backlog را پردازش میکندinterrupt- اجرای فعلی را لغو میکند و از نو شروع میکند
حالت پیشفرض steer است. برای حالتهای پیگیری میتوانید گزینههایی مانند debounce:0.5s cap:25 drop:summarize اضافه کنید. صف فرمان و صف هدایت را ببینید.
موارد متفرقه
مدل پیشفرض Anthropic با یک کلید API چیست؟
در OpenClaw، اعتبارنامهها و انتخاب مدل جدا از هم هستند. تنظیم ANTHROPIC_API_KEY (یا ذخیرهکردن یک کلید API برای Anthropic در پروفایلهای احراز هویت) احراز هویت را فعال میکند، اما مدل پیشفرض واقعی همان چیزی است که در agents.defaults.model.primary پیکربندی میکنید (برای مثال، anthropic/claude-sonnet-4-6 یا anthropic/claude-opus-4-6). اگر No credentials found for profile "anthropic:default" را میبینید، یعنی Gateway نتوانسته اعتبارنامههای Anthropic را در auth-profiles.json مورد انتظار برای agent در حال اجرا پیدا کند.
هنوز گیر کردهاید؟ در Discord بپرسید یا یک گفتوگوی GitHub باز کنید.
مرتبط
- پرسشهای متداول اجرای نخست — نصب، راهاندازی اولیه، احراز هویت، اشتراکها، خطاهای اولیه
- پرسشهای متداول مدلها — انتخاب مدل، failover، پروفایلهای احراز هویت
- عیبیابی — بررسی مشکل بر اساس نشانه