الانتقال إلى المحتوى الرئيسي

Documentation Index

Fetch the complete documentation index at: https://crewai-lorenze-feat-conversational-flows.mintlify.app/llms.txt

Use this file to discover all available pages before exploring further.

الـ Checkpointing يحفظ لقطة من حالة التنفيذ أثناء التشغيل بحيث يمكن لطاقم أو تدفق أو وكيل الاستئناف بعد الفشل أو التفرع إلى فرع بديل.

الشرح

كيف يعمل الـ Checkpointing: الأحداث والتخزين والوراثة.

درس تطبيقي

دليل 5 دقائق: تشغيل، إيقاف، استئناف.

ادلة عملية

وصفات مركزة على المهام لسير العمل الشائع.

المرجع

CheckpointConfig والأحداث والمزودات وسطر الأوامر.

الشرح

ما هي نقطة الحفظ

تلتقط نقطة الحفظ كل ما يحتاجه CrewAI لإعادة إنشاء تشغيل أثناء سيره: الحالة الكاملة للطاقم أو التدفق أو الوكيل — التكوين، وذاكرة الوكلاء ومصادر المعرفة، وتقدم المهام، والمخرجات الوسيطة، والحالة الداخلية والسمات — إلى جانب مدخلات الـ kickoff، وسجل الأحداث حتى تلك النقطة، ومعرف نسب يربط نقطة الحفظ بالتشغيل الذي جاءت منه. الاستعادة تعيد بناء تلك الحالة وتستمر. تتخطى المهام المكتملة، وتعاد ترطيب الذاكرة والمعرفة، ويعمل العمل التابع على نفس المخرجات التي أنتجها التشغيل الأصلي. التفرع يجري نفس الاستعادة تحت نسب جديد، بحيث يكتب الفرع الجديد والتشغيل الأصلي نقاط الحفظ جنبا إلى جنب دون أن يطمس أحدهما الآخر.

متى تكتب نقاط الحفظ

الـ Checkpointing مدفوع بالأحداث. يشترك وقت التشغيل في الأحداث التي تحددها عبر on_events ويكتب نقطة حفظ عند إطلاق أحدها. الافتراضي task_completed ينتج نقطة حفظ لكل مهمة منتهية — توازن معقول بين الدقة واستخدام القرص. الأحداث عالية التردد مثل llm_call_completed متاحة للاستعادة الدقيقة لكنها تكتب ملفات أكثر بكثير.

التخزين

يتضمن CrewAI مزودين:
  • JsonProvider يكتب ملفا لكل نقطة حفظ. قابل للقراءة وسهل التفقد.
  • SqliteProvider يكتب إلى قاعدة بيانات SQLite واحدة. أفضل لنقاط الحفظ عالية التردد.
كلاهما يحذف أقدم نقاط الحفظ عند تحديد max_checkpoints.
كتابة نقاط الحفظ بأفضل جهد. فشل نقطة حفظ يسجل لكنه لا يقاطع التشغيل.

نموذج الوراثة

Crew وFlow وAgent كلها تقبل وسيط checkpoint. يرث الأبناء من الأب ما لم يحددوا قيمتهم الخاصة أو يمرروا False للانسحاب. فعل الـ Checkpointing مرة واحدة على الطاقم وتشارك كل الوكلاء، أو استبعد وكيلا واحدا بشكل انتقائي.

درس تطبيقي: استئناف طاقم فاشل

هذا الدليل يستغرق حوالي 5 دقائق. ستشغل طاقما بمهمتين، توقفه في المنتصف، ثم تستأنف من نقطة الحفظ المحفوظة.
1

أنشئ الطاقم مع تفعيل الـ Checkpointing

from crewai import Agent, Crew, Task

researcher = Agent(role="Researcher", goal="Research", backstory="Expert")
writer = Agent(role="Writer", goal="Write", backstory="Expert")

crew = Crew(
    agents=[researcher, writer],
    tasks=[
        Task(description="Research AI trends", agent=researcher, expected_output="bullets"),
        Task(description="Write a summary", agent=writer, expected_output="paragraph"),
    ],
    checkpoint=True,
)
2

شغله وأوقفه بعد المهمة الأولى

result = crew.kickoff()
اضغط Ctrl+C بعد انتهاء المهمة الأولى. في ./.checkpoints/، الملف بصيغة <timestamp>_<uuid>.json هو نقطة الحفظ.
3

استأنف من نقطة الحفظ

from crewai import CheckpointConfig

result = crew.kickoff(
    from_checkpoint=CheckpointConfig(
        restore_from="./.checkpoints/<timestamp>_<uuid>.json",
    ),
)
يتم تخطي مهمة البحث، ويعمل الكاتب على مخرجات البحث المحفوظة، وينتهي الطاقم.

ادلة عملية

crew = Crew(agents=[...], tasks=[...], checkpoint=True)
يكتب إلى ./.checkpoints/ عند كل task_completed.
from crewai import Crew, CheckpointConfig

crew = Crew(
    agents=[...],
    tasks=[...],
    checkpoint=CheckpointConfig(
        location="./my_checkpoints",
        on_events=["task_completed", "crew_kickoff_completed"],
        max_checkpoints=5,
    ),
)
from crewai import Crew, CheckpointConfig
from crewai.state import JsonProvider

crew = Crew(
    agents=[...],
    tasks=[...],
    checkpoint=CheckpointConfig(
        location="./my_checkpoints",
        provider=JsonProvider(),
        max_checkpoints=5,
    ),
)
SQLite يفعل وضع journal WAL للقراءات المتزامنة. يفضل لنقاط الحفظ عالية التردد.
crew = Crew(
    agents=[
        Agent(role="Researcher", ...),
        Agent(role="Writer", ..., checkpoint=False),
    ],
    tasks=[...],
    checkpoint=True,
)
fork() يستعيد نقطة حفظ تحت نسب جديد بحيث لا يتصادم التشغيل الجديد مع الأصلي.
config = CheckpointConfig(restore_from="./my_checkpoints/<file>.json")
crew = Crew.fork(config, branch="experiment-a")
result = crew.kickoff(inputs={"strategy": "aggressive"})
تسمية branch اختيارية؛ يتم إنشاء واحدة إذا أغفلت.
crew = Crew(
    agents=[researcher, writer],
    tasks=[research_task, write_task, review_task],
    checkpoint=CheckpointConfig(location="./crew_cp"),
)
المشغل الافتراضي: task_completed.
سجل معالجا على أي حدث واستدع state.checkpoint().
from __future__ import annotations

from typing import TYPE_CHECKING, Any

from crewai.events.event_bus import crewai_event_bus
from crewai.events.types.llm_events import LLMCallCompletedEvent

if TYPE_CHECKING:
    from crewai.state.runtime import RuntimeState


@crewai_event_bus.on(LLMCallCompletedEvent)
def on_llm_done(source: Any, event: LLMCallCompletedEvent, state: RuntimeState) -> None:
    path = state.checkpoint("./my_checkpoints")
    print(f"تم حفظ نقطة الحفظ: {path}")
يتم تمرير وسيط state تلقائيا عندما يقبل المعالج ثلاثة معاملات. راجع Event Listeners لقائمة الأحداث الكاملة.
crewai checkpoint
crewai checkpoint --location ./my_checkpoints
crewai checkpoint --location ./.checkpoints.db
Checkpoint TUI tree view
اللوحة اليسرى تجمع نقاط الحفظ حسب الفرع؛ التفرعات تتداخل تحت أبيها. اختيار نقطة حفظ يفتح لوحة التفاصيل مع بياناتها الوصفية وحالة الكيان وتقدم المهام. Resume يكمل التشغيل؛ Fork يبدأ فرعا جديدا.
Checkpoint detail overview tab
لوحة التفاصيل تعرض منطقتين قابلتين للتحرير:
  • Inputs — مدخلات الـ kickoff الأصلية، معبأة مسبقا وقابلة للتحرير.
    Editable kickoff inputs
  • مخرجات المهام — مخرجات المهام المكتملة. تحرير مخرج والضغط على Fork يبطل المهام التابعة لتعاد بالسياق المعدل.
    Editable task outputs
Fork confirmation panel
مفيد لاستكشاف “ماذا لو”: تفرع، عدل، راقب.
crewai checkpoint list ./my_checkpoints
crewai checkpoint info ./my_checkpoints/<file>.json
crewai checkpoint info ./.checkpoints.db

المرجع

CheckpointConfig

location
str
افتراضي:"\"./.checkpoints\""
وجهة التخزين. مجلد لـ JsonProvider، مسار ملف قاعدة بيانات لـ SqliteProvider.
on_events
list[CheckpointEventType | Literal["*"]]
افتراضي:"[\"task_completed\"]"
أنواع الأحداث التي تطلق نقطة حفظ. CheckpointEventType هو Literal — مدقق الأنواع يكمل تلقائيا ويرفض القيم غير المدعومة. راجع أنواع الأحداث للقائمة الكاملة.
provider
BaseProvider
افتراضي:"JsonProvider()"
واجهة التخزين. JsonProvider أو SqliteProvider.
max_checkpoints
int | None
افتراضي:"None"
الحد الاقصى لنقاط الحفظ المحتفظ بها. الأقدم تحذف بعد كل كتابة.
restore_from
Path | str | None
افتراضي:"None"
نقطة الحفظ المراد استعادتها عند تمريرها عبر from_checkpoint.

قيم حقل checkpoint

مقبولة في Crew وFlow وAgent.
None
افتراضي
يرث من الأب.
True
bool
تفعيل بالإعدادات الافتراضية.
False
bool
انسحاب صريح. يوقف الوراثة.
CheckpointConfig(...)
CheckpointConfig
إعدادات مخصصة.

أنواع الأحداث

يقبل on_events أي مجموعة من قيم CheckpointEventType. الافتراضي ["task_completed"] يكتب نقطة حفظ لكل مهمة منتهية، و["*"] يطابق جميع الأحداث.
["*"] والأحداث عالية التردد مثل llm_call_completed تكتب نقاط حفظ كثيرة وقد تضر بالاداء. استخدمها مع max_checkpoints.

مزودات التخزين

JsonProvider
provider
ملف واحد لكل نقطة حفظ بصيغة <timestamp>_<uuid>.json داخل location.
SqliteProvider
provider
ملف قاعدة بيانات واحد في location مع journaling WAL.

سطر الأوامر

الامرالغرض
crewai checkpointتشغيل TUI؛ كشف التخزين تلقائيا.
crewai checkpoint --location <path>تشغيل TUI على موقع محدد.
crewai checkpoint list <path>سرد نقاط الحفظ.
crewai checkpoint info <path>تفقد ملف نقطة حفظ أو آخر مدخل في قاعدة بيانات SQLite.