CLI commands
Cron
openclaw cron
จัดการงาน Cron สำหรับตัวกำหนดตารางเวลาของ Gateway
เซสชัน
--session รับค่า main, isolated, current หรือ session:<id>
คีย์เซสชัน
mainผูกกับเซสชันหลักของ agentisolatedสร้างทรานสคริปต์ใหม่และ id เซสชันใหม่สำหรับการรันแต่ละครั้งcurrentผูกกับเซสชันที่ใช้งานอยู่ ณ เวลาสร้างsession:<id>ปักหมุดกับคีย์เซสชันถาวรที่ระบุอย่างชัดเจน
ความหมายของเซสชันแบบแยก
การรันแบบแยกจะรีเซ็ตบริบทการสนทนาแวดล้อม การกำหนดเส้นทางช่องทางและกลุ่ม นโยบายส่ง/เข้าคิว การยกระดับ ต้นทาง และการผูก runtime ของ ACP จะถูกรีเซ็ตสำหรับการรันใหม่ ค่ากำหนดที่ปลอดภัยและการ override โมเดลหรือ auth ที่ผู้ใช้เลือกไว้อย่างชัดเจนสามารถส่งต่อข้ามการรันได้
การส่งมอบ
openclaw cron list และ openclaw cron show <job-id> แสดงตัวอย่างเส้นทางการส่งมอบที่ resolve แล้ว สำหรับ channel: "last" ตัวอย่างจะแสดงว่าเส้นทาง resolve จากเซสชันหลักหรือเซสชันปัจจุบัน หรือจะ fail closed
เป้าหมายที่มี provider เป็น prefix สามารถทำให้ช่องทางประกาศที่ยังไม่ resolve มีความชัดเจนได้ ตัวอย่างเช่น to: "telegram:123" เลือก Telegram เมื่อ delivery.channel ถูกละไว้หรือเป็น last เฉพาะ prefix ที่ Plugin ที่โหลดประกาศไว้เท่านั้นที่เป็นตัวเลือก provider หาก delivery.channel ระบุไว้อย่างชัดเจน prefix ต้องตรงกับช่องทางนั้น; channel: "whatsapp" พร้อม to: "telegram:123" จะถูกปฏิเสธ prefix ของบริการ เช่น imessage: และ sms: ยังคงเป็นไวยากรณ์เป้าหมายที่ช่องทางเป็นเจ้าของ
ความเป็นเจ้าของการส่งมอบ
การส่งมอบแชท Cron แบบแยกถูกแชร์ระหว่าง agent และ runner:
- agent สามารถส่งโดยตรงด้วยเครื่องมือ
messageเมื่อมีเส้นทางแชทพร้อมใช้งาน announceส่งมอบคำตอบสุดท้ายแบบ fallback เฉพาะเมื่อ agent ไม่ได้ส่งโดยตรงไปยังเป้าหมายที่ resolve แล้วwebhookโพสต์ payload ที่เสร็จแล้วไปยัง URLnoneปิดการส่งมอบ fallback ของ runner
--announce คือการส่งมอบ fallback ของ runner สำหรับคำตอบสุดท้าย --no-deliver ปิด fallback นั้น แต่ไม่ได้เอาเครื่องมือ message ของ agent ออกเมื่อมีเส้นทางแชทพร้อมใช้งาน
การเตือนความจำที่สร้างจากแชทที่ใช้งานอยู่จะรักษาเป้าหมายการส่งมอบแชทสดไว้สำหรับการส่งมอบประกาศแบบ fallback คีย์เซสชันภายในอาจเป็นตัวพิมพ์เล็ก อย่าใช้คีย์เหล่านี้เป็นแหล่งความจริงสำหรับ ID provider ที่แยกตัวพิมพ์เล็กใหญ่ เช่น ID ห้อง Matrix
การส่งมอบเมื่อเกิดความล้มเหลว
การแจ้งเตือนความล้มเหลว resolve ตามลำดับนี้:
delivery.failureDestinationบนงานcron.failureDestinationส่วนกลาง- เป้าหมายประกาศหลักของงาน (เมื่อไม่ได้ตั้งค่าปลายทางความล้มเหลวไว้อย่างชัดเจน)
หมายเหตุ: การรัน Cron แบบแยกถือว่าความล้มเหลวของ agent ระดับการรันเป็นข้อผิดพลาดของงาน แม้เมื่อ ไม่มีการสร้าง payload คำตอบ ดังนั้นความล้มเหลวของโมเดล/provider ยังคงเพิ่มตัวนับข้อผิดพลาด และทริกเกอร์การแจ้งเตือนความล้มเหลว
การกำหนดตารางเวลา
งานแบบครั้งเดียว
--at <datetime> กำหนดเวลาการรันแบบครั้งเดียว datetime ที่ไม่มี offset จะถือเป็น UTC เว้นแต่คุณจะส่ง --tz <iana> ด้วย ซึ่งจะตีความเวลาแบบ wall-clock ในเขตเวลาที่กำหนด
งานที่เกิดซ้ำ
งานที่เกิดซ้ำใช้ exponential retry backoff หลังจากเกิดข้อผิดพลาดต่อเนื่อง: 30s, 1m, 5m, 15m, 60m ตารางเวลาจะกลับสู่ภาวะปกติหลังการรันครั้งถัดไปที่สำเร็จ
การรันที่ถูกข้ามจะถูกติดตามแยกจากข้อผิดพลาดในการดำเนินการ การรันเหล่านี้ไม่ส่งผลต่อ retry backoff แต่ openclaw cron edit <job-id> --failure-alert-include-skipped สามารถเลือกให้การแจ้งเตือนความล้มเหลวรวมการแจ้งเตือนการรันที่ถูกข้ามซ้ำได้
สำหรับงานแบบแยกที่กำหนดเป้าหมายไปยัง provider โมเดลที่กำหนดค่าไว้ในเครื่อง Cron จะรัน provider preflight แบบเบาก่อนเริ่มเทิร์นของ agent provider api: "ollama" แบบ loopback, เครือข่ายส่วนตัว และ .local จะถูก probe ที่ /api/tags; provider ที่เข้ากันได้กับ OpenAI ในเครื่อง เช่น vLLM, SGLang และ LM Studio จะถูก probe ที่ /models หาก endpoint เข้าถึงไม่ได้ การรันจะถูกบันทึกเป็น skipped และ retry ในตารางเวลาภายหลัง; endpoint ที่ตรงกันและตายแล้วจะถูกแคชไว้ 5 นาทีเพื่อหลีกเลี่ยงไม่ให้งานจำนวนมากถล่ม server ในเครื่องเดียวกัน
หมายเหตุ: นิยามงาน Cron อยู่ใน jobs.json ขณะที่สถานะ runtime ที่รอดำเนินการอยู่ใน jobs-state.json หาก jobs.json ถูกแก้ไขจากภายนอก Gateway จะโหลดตารางเวลาที่เปลี่ยนแปลงใหม่และล้าง slot ที่รอดำเนินการซึ่งค้างอยู่ การเขียนซ้ำที่เปลี่ยนเฉพาะรูปแบบจะไม่ล้าง slot ที่รอดำเนินการ
การรันด้วยตนเอง
openclaw cron run ส่งคืนทันทีที่การรันด้วยตนเองถูกเข้าคิว การตอบกลับที่สำเร็จมี { ok: true, enqueued: true, runId } ใช้ openclaw cron runs --id <job-id> เพื่อติดตามผลลัพธ์ในท้ายที่สุด
โมเดล
cron add|edit --model <ref> เลือกโมเดลที่อนุญาตสำหรับงาน
Cron --model เป็น ตัวหลักของงาน ไม่ใช่ override /model ของเซสชันแชท นั่นหมายความว่า:
- fallback ของโมเดลที่กำหนดค่ายังคงมีผลเมื่อโมเดลงานที่เลือกไว้ล้มเหลว
- payload ต่อรายการงาน
fallbacksจะแทนที่รายการ fallback ที่กำหนดค่าไว้เมื่อมีอยู่ - รายการ fallback ต่อรายการงานที่ว่างเปล่า (
fallbacks: []ใน payload/API ของงาน) ทำให้การรัน Cron เป็นแบบเข้มงวด - เมื่องานมี
--modelแต่ไม่มีการกำหนดค่ารายการ fallback OpenClaw จะส่ง fallback override ที่ว่างเปล่าอย่างชัดเจน เพื่อไม่ให้ตัวหลักของ agent ถูกผนวกเป็นเป้าหมาย retry ที่ซ่อนอยู่
ลำดับความสำคัญของโมเดล Cron แบบแยก
Cron แบบแยก resolve โมเดลที่ใช้งานอยู่ตามลำดับนี้:
- override ของ Gmail-hook
--modelต่อรายการงาน- override โมเดลเซสชัน Cron ที่เก็บไว้ (เมื่อผู้ใช้เลือกไว้)
- การเลือกโมเดลของ agent หรือค่าเริ่มต้น
โหมดเร็ว
โหมดเร็วของ Cron แบบแยกจะตามการเลือกโมเดลสดที่ resolve แล้ว ค่า config โมเดล params.fastMode มีผลโดยค่าเริ่มต้น แต่ override fastMode ของเซสชันที่เก็บไว้ยังคงชนะ config
การ retry การสลับโมเดลสด
หากการรันแบบแยกโยน LiveSessionModelSwitchError Cron จะ persist provider และโมเดลที่สลับแล้ว (และ override โปรไฟล์ auth ที่สลับแล้วเมื่อมี) สำหรับการรันที่ใช้งานอยู่ก่อน retry ลูป retry ภายนอกถูกจำกัดไว้ที่การ retry การสลับสองครั้งหลังความพยายามแรก จากนั้น abort แทนที่จะวนซ้ำตลอดไป
ผลลัพธ์การรันและการปฏิเสธ
การกดทับ acknowledgement ที่ค้างเก่า
เทิร์น Cron แบบแยกจะกดทับคำตอบที่เป็นเพียง acknowledgement ที่ค้างเก่า หากผลลัพธ์แรกเป็นเพียงการอัปเดตสถานะชั่วคราวและไม่มีการรัน subagent ลูกหลานรับผิดชอบคำตอบในท้ายที่สุด Cron จะ prompt ซ้ำหนึ่งครั้งเพื่อขอผลลัพธ์จริงก่อนส่งมอบ
การกดทับ silent token
หากการรัน Cron แบบแยกคืนค่าเฉพาะ silent token (NO_REPLY หรือ no_reply) Cron จะกดทับทั้งการส่งมอบขาออกโดยตรงและเส้นทางสรุปที่เข้าคิวแบบ fallback ดังนั้นจะไม่มีสิ่งใดถูกโพสต์กลับไปยังแชท
การปฏิเสธแบบมีโครงสร้าง
การรัน Cron แบบแยกจะให้ความสำคัญกับ metadata การปฏิเสธการดำเนินการแบบมีโครงสร้างจากการรันที่ฝังไว้ก่อน จากนั้น fallback ไปยัง marker การปฏิเสธที่รู้จักในผลลัพธ์สุดท้าย เช่น SYSTEM_RUN_DENIED, INVALID_REQUEST และวลีปฏิเสธการผูก approval
cron list และประวัติการรันจะแสดงเหตุผลการปฏิเสธแทนการรายงานคำสั่งที่ถูกบล็อกเป็น ok
การเก็บรักษา
การเก็บรักษาและการ prune ถูกควบคุมใน config:
cron.sessionRetention(ค่าเริ่มต้น24h) prune เซสชันการรันแบบแยกที่เสร็จสมบูรณ์cron.runLog.maxBytesและcron.runLog.keepLinesprune~/.openclaw/cron/runs/<jobId>.jsonl
การย้ายงานเก่า
การแก้ไขทั่วไป
อัปเดตการตั้งค่าการส่งมอบโดยไม่เปลี่ยนข้อความ:
openclaw cron edit <job-id> --announce --channel telegram --to "123456789"
ปิดการส่งมอบสำหรับงานแบบแยก:
openclaw cron edit <job-id> --no-deliver
เปิดใช้บริบท bootstrap แบบเบาสำหรับงานแบบแยก:
openclaw cron edit <job-id> --light-context
ประกาศไปยังช่องทางที่ระบุ:
openclaw cron edit <job-id> --announce --channel slack --to "channel:C1234567890"
ประกาศไปยังหัวข้อฟอรัม Telegram:
openclaw cron edit <job-id> --announce --channel telegram --to "-1001234567890" --thread-id 42
สร้างงานแบบแยกพร้อมบริบท bootstrap แบบเบา:
openclaw cron add \
--name "Lightweight morning brief" \
--cron "0 7 * * *" \
--session isolated \
--message "Summarize overnight updates." \
--light-context \
--no-deliver
--light-context ใช้กับงาน Cron แบบ agent-turn ที่แยกเท่านั้น สำหรับการรัน Cron โหมดเบาจะคงบริบท bootstrap ให้ว่างเปล่าแทนการ inject ชุด bootstrap ทั้งหมดของ workspace
คำสั่งผู้ดูแลทั่วไป
การรันด้วยตนเองและการตรวจสอบ:
openclaw cron list
openclaw cron list --agent ops
openclaw cron show <job-id>
openclaw cron run <job-id>
openclaw cron run <job-id> --due
openclaw cron runs --id <job-id> --limit 50
openclaw cron list แสดงงานทั้งหมดที่ตรงกันโดยค่าเริ่มต้น ส่ง --agent <id> เพื่อแสดงเฉพาะงานที่ id ของ agent แบบ normalized ที่มีผลตรงกัน; งานที่ไม่มี id ของ agent ที่เก็บไว้นับเป็น agent เริ่มต้นที่กำหนดค่าไว้
cron list --json และ cron show <job-id> --json รวมฟิลด์ status ระดับบนในแต่ละงาน ซึ่งคำนวณจาก enabled, state.runningAtMs และ state.lastRunStatus ค่า: disabled, running, ok, error, skipped หรือ idle สิ่งนี้สะท้อนคอลัมน์สถานะที่มนุษย์อ่านได้ เพื่อให้เครื่องมือภายนอกอ่านสถานะงานได้โดยไม่ต้อง derive ใหม่
รายการ cron runs รวม diagnostics การส่งมอบพร้อมเป้าหมาย Cron ที่ตั้งใจไว้ เป้าหมายที่ resolve แล้ว การส่งผ่าน message-tool การใช้ fallback และสถานะการส่งมอบ
การกำหนดเป้าหมาย agent และเซสชันใหม่:
openclaw cron edit <job-id> --agent ops
openclaw cron edit <job-id> --clear-agent
openclaw cron edit <job-id> --session current
openclaw cron edit <job-id> --session "session:daily-brief"
openclaw cron add เตือนเมื่อ --agent ถูกละไว้ในงานแบบ agent-turn และ fallback ไปยัง agent เริ่มต้น (main) ส่ง --agent <id> ณ เวลาสร้างเพื่อปักหมุด agent ที่ระบุ
การปรับแต่งการส่งมอบ:
openclaw cron edit <job-id> --announce --channel slack --to "channel:C1234567890"
openclaw cron edit <job-id> --best-effort-deliver
openclaw cron edit <job-id> --no-best-effort-deliver
openclaw cron edit <job-id> --no-deliver