CLI commands
อัปเดต
OmeniaClaw update
อัปเดต OmeniaClaw อย่างปลอดภัยและสลับระหว่างช่องทาง stable/beta/dev
หากคุณติดตั้งผ่าน npm/pnpm/bun (ติดตั้งแบบ global ไม่มีข้อมูลเมตา git) การอัปเดตจะเกิดขึ้นผ่านขั้นตอน package-manager ใน การอัปเดต
การใช้งาน
OmeniaClaw updateOmeniaClaw update statusOmeniaClaw update wizardOmeniaClaw update --channel betaOmeniaClaw update --channel devOmeniaClaw update --tag betaOmeniaClaw update --tag mainOmeniaClaw update --dry-runOmeniaClaw update --no-restartOmeniaClaw update --yesOmeniaClaw update --jsonOmeniaClaw --updateตัวเลือก
--no-restart: ข้ามการรีสตาร์ตบริการ Gateway หลังการอัปเดตสำเร็จ การอัปเดตผ่าน package-manager ที่รีสตาร์ต Gateway จะตรวจสอบว่าบริการที่รีสตาร์ตรายงานเวอร์ชันที่อัปเดตตามที่คาดไว้ก่อนที่คำสั่งจะสำเร็จ--channel <stable|beta|dev>: ตั้งค่าช่องทางอัปเดต (git + npm; บันทึกไว้ในคอนฟิก)--tag <dist-tag|version|spec>: แทนที่เป้าหมายแพ็กเกจสำหรับการอัปเดตครั้งนี้เท่านั้น สำหรับการติดตั้งแบบแพ็กเกจmainจะแมปไปยังgithub:OmeniaClaw/OmeniaClaw#main--dry-run: ดูตัวอย่างการดำเนินการอัปเดตที่วางแผนไว้ (ช่องทาง/แท็ก/เป้าหมาย/ขั้นตอนรีสตาร์ต) โดยไม่เขียนคอนฟิก ติดตั้ง ซิงก์ plugins หรือรีสตาร์ต--json: พิมพ์ JSONUpdateRunResultที่เครื่องอ่านได้ รวมถึงpostUpdate.plugins.warningsเมื่อ plugins ที่จัดการอยู่เสียหายหรือโหลดไม่ได้และต้อง ซ่อมแซมหลังการอัปเดตแกนหลักสำเร็จ รายละเอียดการถอยกลับของ Plugin ในช่องทาง beta เมื่อ Plugin ไม่มีรุ่น beta และpostUpdate.plugins.integrityDriftsเมื่อพบความคลาดเคลื่อนของอาร์ติแฟกต์ Plugin ของ npm ระหว่างการซิงก์ Plugin หลังอัปเดต--timeout <seconds>: เวลาหมดอายุต่อขั้นตอน (ค่าเริ่มต้นคือ 1800 วินาที)--yes: ข้ามพรอมป์ยืนยัน (เช่น การยืนยันการดาวน์เกรด)
OmeniaClaw update ไม่มีแฟล็ก --verbose ใช้ --dry-run เพื่อดูตัวอย่าง
การดำเนินการช่องทาง/แท็ก/ติดตั้ง/รีสตาร์ตที่วางแผนไว้, --json สำหรับผลลัพธ์
ที่เครื่องอ่านได้ และ OmeniaClaw update status --json เมื่อคุณต้องการเฉพาะรายละเอียด
ช่องทางและความพร้อมใช้งาน หากคุณกำลังดีบักบันทึก Gateway ในช่วงการอัปเดต
ระดับความละเอียดของคอนโซลและระดับบันทึกไฟล์จะแยกกัน: Gateway --verbose มีผลต่อ
เอาต์พุตเทอร์มินัล/WebSocket ขณะที่บันทึกไฟล์ต้องใช้ logging.level: "debug" หรือ
"trace" ในคอนฟิก ดู การบันทึก Gateway
update status
แสดงช่องทางอัปเดตที่ใช้งานอยู่ + แท็ก/สาขา/SHA ของ git (สำหรับ source checkouts) พร้อมสถานะความพร้อมของอัปเดต
OmeniaClaw update statusOmeniaClaw update status --jsonOmeniaClaw update status --timeout 10ตัวเลือก:
--json: พิมพ์ JSON สถานะที่เครื่องอ่านได้--timeout <seconds>: เวลาหมดอายุสำหรับการตรวจสอบ (ค่าเริ่มต้นคือ 3 วินาที)
update wizard
ขั้นตอนแบบโต้ตอบเพื่อเลือกช่องทางอัปเดตและยืนยันว่าจะรีสตาร์ต Gateway
หลังอัปเดตหรือไม่ (ค่าเริ่มต้นคือรีสตาร์ต) หากคุณเลือก dev โดยไม่มี git checkout ระบบจะ
เสนอให้สร้างให้
ตัวเลือก:
--timeout <seconds>: เวลาหมดอายุสำหรับแต่ละขั้นตอนการอัปเดต (ค่าเริ่มต้น1800)
สิ่งที่ทำ
เมื่อคุณสลับช่องทางอย่างชัดเจน (--channel ...) OmeniaClaw จะรักษา
วิธีติดตั้งให้สอดคล้องกันด้วย:
dev→ รับประกันว่ามี git checkout (ค่าเริ่มต้น:~/OmeniaClaw, แทนที่ด้วยOmeniaClaw_GIT_DIR), อัปเดต checkout นั้น และติดตั้ง CLI แบบ global จาก checkout นั้นstable→ ติดตั้งจาก npm โดยใช้latestbeta→ ให้ความสำคัญกับ npm dist-tagbetaแต่ถอยกลับไปใช้latestเมื่อ beta ไม่มีหรือเก่ากว่ารุ่น stable ปัจจุบัน
ตัวอัปเดตอัตโนมัติของแกน Gateway (เมื่อเปิดใช้ผ่านคอนฟิก) จะเปิดเส้นทางอัปเดต CLI
ภายนอกตัวจัดการคำขอ Gateway ที่กำลังทำงานอยู่ การอัปเดต package-manager ผ่าน control-plane update.run
จะบังคับให้มีการรีสตาร์ตอัปเดตแบบไม่เลื่อนเวลาและไม่มีคูลดาวน์หลังการสลับแพ็กเกจ
เพราะกระบวนการ Gateway เก่าอาจยังมีชิ้นส่วนในหน่วยความจำที่ชี้ไปยัง
ไฟล์ที่แพ็กเกจใหม่ลบออกแล้ว
สำหรับการติดตั้งผ่าน package-manager, OmeniaClaw update จะแก้หาเวอร์ชัน
แพ็กเกจเป้าหมายก่อนเรียก package manager การติดตั้ง npm แบบ global ใช้การติดตั้งแบบจัดเตรียม:
OmeniaClaw ติดตั้งแพ็กเกจใหม่ลงใน prefix ชั่วคราวของ npm ตรวจสอบ
รายการ dist ที่แพ็กเกจไว้ที่นั่น แล้วจึงสลับ tree ของแพ็กเกจที่สะอาดนั้นเข้าไปใน
prefix global จริง หากการตรวจสอบล้มเหลว งาน doctor หลังอัปเดต การซิงก์ Plugin และ
การรีสตาร์ตจะไม่รันจาก tree ที่น่าสงสัยนั้น แม้เวอร์ชันที่ติดตั้งอยู่
จะตรงกับเป้าหมายแล้ว คำสั่งก็จะรีเฟรชการติดตั้งแพ็กเกจ global,
จากนั้นรันการซิงก์ Plugin, การรีเฟรช completion ของคำสั่งแกนหลัก และงานรีสตาร์ต สิ่งนี้
ช่วยให้ sidecar ที่แพ็กเกจไว้และระเบียน Plugin ที่ช่องทางเป็นเจ้าของสอดคล้องกับ
บิลด์ OmeniaClaw ที่ติดตั้งอยู่ ขณะที่ปล่อยให้การสร้าง completion ของคำสั่ง Plugin แบบเต็ม
ทำผ่านการรัน OmeniaClaw completion --write-state อย่างชัดเจน
เมื่อมีบริการ Gateway ในเครื่องที่จัดการอยู่ติดตั้งไว้และเปิดใช้การรีสตาร์ต
การอัปเดตผ่าน package-manager จะหยุดบริการที่กำลังทำงานก่อนแทนที่ tree ของแพ็กเกจ
จากนั้นรีเฟรชข้อมูลเมตาของบริการจากการติดตั้งที่อัปเดต รีสตาร์ต
บริการ และตรวจสอบว่า Gateway ที่รีสตาร์ตรายงานเวอร์ชันที่คาดไว้ก่อน
รายงานว่าสำเร็จ บน macOS การตรวจสอบหลังอัปเดตยังตรวจสอบว่า LaunchAgent
ถูกโหลด/ทำงานสำหรับโปรไฟล์ที่ใช้งานอยู่ และพอร์ตลูปแบ็กที่กำหนดค่าไว้
มีสถานะปกติ หากติดตั้ง plist แล้วแต่ launchd ไม่ได้กำกับดูแลอยู่ OmeniaClaw
จะ bootstrap LaunchAgent ใหม่โดยอัตโนมัติ แล้วรันการตรวจสอบ
ความพร้อมด้านสุขภาพ/เวอร์ชัน/ช่องทางอีกครั้ง bootstrap ใหม่จะโหลดงาน RunAtLoad
โดยตรง ดังนั้นการกู้คืนอัปเดตจะไม่ kickstart -k Gateway ที่เพิ่ง
เริ่มขึ้นทันที หาก Gateway ยังไม่พร้อมใช้งาน คำสั่งจะออกด้วย
รหัสไม่เป็นศูนย์และพิมพ์เส้นทางบันทึกการรีสตาร์ต พร้อมคำสั่งรีสตาร์ต ติดตั้งใหม่ และ
ย้อนกลับแพ็กเกจอย่างชัดเจน เมื่อใช้ --no-restart,
การแทนที่แพ็กเกจยังคงรัน แต่บริการที่จัดการอยู่จะไม่ถูกหยุดหรือ
รีสตาร์ต ดังนั้น Gateway ที่กำลังทำงานอาจยังใช้โค้ดเก่าจนกว่าคุณจะรีสตาร์ต
ด้วยตนเอง
ขั้นตอน git checkout
การเลือกช่องทาง
stable: checkout แท็ก non-beta ล่าสุด จากนั้น build และ doctorbeta: ให้ความสำคัญกับแท็ก-betaล่าสุด แต่ถอยกลับไปใช้แท็ก stable ล่าสุดเมื่อ beta ไม่มีหรือเก่ากว่าdev: checkoutmainจากนั้น fetch และ rebase
ขั้นตอนการอัปเดต
ตรวจสอบ worktree ที่สะอาด
ต้องไม่มีการเปลี่ยนแปลงที่ยังไม่ได้ commit
สลับช่องทาง
สลับไปยังช่องทางที่เลือก (แท็กหรือสาขา)
ดึงข้อมูลจาก upstream
เฉพาะ Dev
บิลด์ตรวจล่วงหน้า (เฉพาะ dev)
รันบิลด์ TypeScript ใน worktree ชั่วคราว หาก tip ล้มเหลว จะถอยกลับได้สูงสุด 10 commits เพื่อหา commit ล่าสุดที่ build ได้ ตั้งค่า OmeniaClaw_UPDATE_PREFLIGHT_LINT=1 เพื่อรัน lint ระหว่างการตรวจล่วงหน้านี้ด้วย; lint จะรันในโหมด serial แบบจำกัด เพราะโฮสต์อัปเดตของผู้ใช้มักเล็กกว่า runner ของ CI
Rebase
rebase ไปยัง commit ที่เลือก (เฉพาะ dev)
ติดตั้ง dependencies
ใช้ package manager ของ repo สำหรับ checkout ที่ใช้ pnpm ตัวอัปเดตจะ bootstrap pnpm เมื่อต้องการ (ผ่าน corepack ก่อน จากนั้นใช้ fallback ชั่วคราว npm install pnpm@11) แทนการรัน npm run build ภายใน workspace ของ pnpm
Build Control UI
build gateway และ Control UI
Run doctor
OmeniaClaw doctor รันเป็นการตรวจสอบ safe-update ขั้นสุดท้าย
Sync plugins
ซิงก์ plugins ไปยังช่องทางที่ใช้งานอยู่ Dev ใช้ plugins ที่ bundled มา; stable และ beta ใช้ npm อัปเดตการติดตั้ง Plugin ที่ติดตามอยู่
บนช่องทางอัปเดต beta การติดตั้ง Plugin ของ npm และ ClawHub ที่ติดตามอยู่และตาม
สาย default/latest จะลองใช้รุ่น Plugin @beta ก่อน หาก Plugin ไม่มี
รุ่น beta, OmeniaClaw จะถอยกลับไปใช้ spec default/latest ที่บันทึกไว้และรายงาน
เป็นคำเตือน สำหรับ plugins ของ npm, OmeniaClaw จะถอยกลับเช่นกันเมื่อมีแพ็กเกจ beta
แต่ไม่ผ่านการตรวจสอบการติดตั้ง คำเตือนการถอยกลับของ Plugin เหล่านี้
ไม่ทำให้การอัปเดตแกนหลักล้มเหลว เวอร์ชันแบบเจาะจงและแท็กแบบชัดเจนจะไม่ถูก
เขียนใหม่
ชวเลข --update
OmeniaClaw --update จะเขียนใหม่เป็น OmeniaClaw update (มีประโยชน์สำหรับ shell และสคริปต์ launcher)
ที่เกี่ยวข้อง
OmeniaClaw doctor(เสนอให้รัน update ก่อนบน git checkouts)- ช่องทางการพัฒนา
- การอัปเดต
- เอกสารอ้างอิง CLI