سیستم ابزار BoxAgnts: مهارت‌ها، عامل‌ها و زمان‌بندی

یک سیستم کامل عامل هوش مصنوعی (AI Agent) به چیزی فراتر از ابزارهای پایه نیاز دارد. این سیستم به سه قابلیت خاص نیاز دارد: بازاستفاده از دانش، تجزیه وظایف و اجرای خودکار.

BoxAgnts از سه مکانیزم برای حل این مشکلات استفاده می‌کند: قالب‌های مهارت (Skill templates)، زیر-عامل‌های Agent و زمان‌بندی Cron.

قالب‌های مهارت (بازاستفاده از دانش)

وقتی از یک هوش مصنوعی می‌خواهید «این کد را بررسی کن»، خواهان نتایج یکپارچه هستید. اگر هوش مصنوعی هر بار فرآیند را از صفر تصمیم‌گیری کند، کیفیت نتایج متغیر خواهد بود.

یک Skill در واقع یک قالب پرامپت Markdown است. هوش مصنوعی یک مهارت را فراخوانی می‌کند، مجموعه‌ای از دستورالعمل‌های دقیق را دریافت می‌کند و سپس کار را اجرا می‌کند.

تفاوت اصلی بین یک Tool و یک Skill در این است که چه کسی کار را انجام می‌دهد:

  • سیستم یک Tool را اجرا می‌کند.
  • هوش مصنوعی یک Skill را اجرا می‌کند.

مهارت‌ها تعیین می‌کنند که یک وظیفه چگونه انجام شود و خروجی باید چگونه باشد.

زیر-عامل‌های Agent (تجزیه وظایف)

وظایف بزرگ با دو محدودیت مواجه می‌شوند: پنجره بافت (context window) و کاهش توجه (attention decay). اگر یک گفتگو بیش از حد طولانی شود، هوش مصنوعی اطلاعات اولیه را فراموش می‌کند.

زیر-عامل‌های Agent این مشکل را با تقسیم یک وظیفه بزرگ به وظایف کوچک‌تر و مستقل حل می‌کنند. هر زیر-عامل پنجره بافت مخصوص به خود را دارد.

شما می‌توانید از دو حالت استفاده کنید:

  • همگام (Synchronous): عامل اصلی منتظر می‌ماند تا زیر-عامل کار خود را تمام کند.
  • ناهمگام (Asynchronous): زیر-عامل در پس‌زمینه اجرا می‌شود در حالی که عامل اصلی مشغول انجام کارهای دیگر است.

این کار از «آلودگی بافت» (context pollution) جلوگیری کرده و امکان کار موازی را فراهم می‌کند.

زمان‌بندی Cron (اجرای خودکار)

همه وظایف در زمان واقعی انجام نمی‌شوند. ممکن است بخواهید هر روز صبح ساعت ۹، یک گزارش کیفیت کد دریافت کنید.

سیستم Cron در BoxAgnts وظایف زمان‌بندی شده را مدیریت می‌کند. هر وظیفه دارای ویژگی‌های زیر است:

  • محافظت مستقل در برابر اتمام زمان (timeout) برای جلوگیری از فرآیندهای کنترل‌نشده.
  • پایداری با SQLite تا وظایف پس از بازنشانی (restart) از بین نروند.
  • نشست‌های (sessions) ایزوله برای تمیز نگه داشتن تاریخچه.

پشتیبانی زیرساختی

دو ویژگی دیگر این سیستم را پایدار می‌کنند:

  • AutoCompactState: این ویژگی زمانی که تاریخچه گفتگو بسیار بزرگ می‌شود، نتایج قدیمی ابزارها را فشرده می‌کند. این کار منطق اخیر را حفظ کرده و در عین حال داده‌های قدیمی را خلاصه می‌کند.
  • فیلتر کردن مجوزها (Permission Filtering): شما می‌توانید عامل‌های «فقط خواندنی» (read-only) ایجاد کنید. این عامل‌ها می‌توانند فایل‌ها را ببینند اما نمی‌توانند آن‌ها را تغییر دهند یا دستورات bash را اجرا کنند.

BoxAgents فراتر از فراخوانی ساده ابزارها حرکت می‌کند تا یک لایه ارکستراسیون (orchestration) ساختاریافته و قابل اعتماد برای عامل‌ها ایجاد کند.

سیستم ابزار BoxAGNTs: ۷. قالب‌های مهارت، پروکسی‌های عامل و زمان‌بندی Cron

در این بخش از این مجموعه، ما به سه ویژگی قدرتمند دیگر می‌پردازیم که قابلیت‌های سیستم BoxAGNTs را ارتقا می‌دهند: قالب‌های مهارت (Skill Templates)، پروکسی‌های عامل (Agent Proxies) و زمان‌بندی Cron.

۱. قالب‌های مهارت (Skill Templates)

یکی از چالش‌های اصلی در مدیریت عامل‌های متعدد، تعریف مجدد ابزارها و قابلیت‌ها برای هر عامل است. قالب‌های مهارت این مشکل را با فراهم کردن یک ساختار قابل استفاده مجدد حل می‌کنند.

با استفاده از قالب‌های مهارت، شما می‌توانید یک مجموعه از ابزارها، پارامترهای ورودی و منطق‌های اجرایی را تعریف کنید و سپس آن را به چندین عامل مختلف اختصاص دهید. این کار باعث می‌شود که توسعه عامل‌های جدید بسیار سریع‌تر و با خطای کمتر انجام شود.

مزایای قالب‌های مهارت:

  • قابلیت استفاده مجدد (Reusability): یک بار تعریف کنید و در چندین عامل از آن استفاده کنید.
  • ثبات (Consistency): اطمینان حاصل کنید که همه عامل‌ها از همان نسخه و منطق یک مهارت استفاده می‌کنند.
  • مدیریت آسان: به‌روزرسانی یک قالب، تمام عامل‌های متصل به آن را به‌روز می‌کند.

۲. پروکسی‌های عامل (Agent Proxies)

در سیستم‌های پیچیده، مدیریت ارتباط با ده‌ها یا صدها عامل به صورت مستقیم بسیار دشوار است. پروکسی‌های عامل به عنوان یک لایه واسط (intermediary layer) عمل می‌کنند.

یک پروکسی عامل می‌تواند درخواست‌ها را دریافت کرده، آن‌ها را به عامل مناسب هدایت کند و پاسخ‌ها را مدیریت کند. این کار باعث می‌شود که کلاینت‌ها نیازی به دانستن جزئیات پیاده‌سازی یا آدرس دقیق هر عامل نداشته باشند و تنها با یک نقطه اتصال (endpoint) واحد تعامل کنند.

کاربردهای پروکسی‌های عامل:

  • انتزاع (Abstraction): پنهان کردن پیچیدگی‌های زیرساختی عامل‌ها از کاربر نهایی.
  • امنیت: کنترل دسترسی و احراز هویت در یک نقطه واحد و متمرکز.
  • توزیع بار (Load Balancing): توزیع درخواست‌ها بین چندین نمونه از یک عامل برای جلوگیری از فشار بیش از حد.

۳. زمان‌بندی Cron (Cron Scheduling)

بسیاری از وظایف عامل‌ها نباید فقط بر اساس درخواست‌های لحظه‌ای کاربر، بلکه باید بر اساس زمان نیز اجرا شوند. زمان‌بندی Cron این امکان را فراهم می‌کند که عامل‌ها وظایف خود را در فواصل زمانی مشخص یا در زمان‌های معینی از روز به صورت خودکار انجام دهند.

با استفاده از عبارت‌های Cron (Cron expressions)، می‌توانید دقت بسیار بالایی در زمان‌بندی داشته باشید؛ از اجرای هر دقیقه تا اجرای یک بار در هفته یا ماه.

مثال‌های کاربردی:

  • بررسی روزانه ایمیل‌ها در ساعت ۸ صبح.
  • تولید گزارش‌های هفتگی هر جمعه ساعت ۱۲ شب.
  • پاکسازی خودکار داده‌های قدیمی یا حافظه در ساعات کم‌ترافیک.

منبع: https://dev.to/guyoung/boxagnts-tool-system-7-skill-templates-agent-proxies-and-cron-scheduling-1o3h

جامعه یادگیری اختیاری: https://t.me/GyaanSetuAi