Maintenance
Memperbarui
Jaga OpenClaw tetap mutakhir.
Direkomendasikan: openclaw update
Cara tercepat untuk memperbarui. Perintah ini mendeteksi jenis instalasi Anda (npm atau git), mengambil versi terbaru, menjalankan openclaw doctor, dan memulai ulang gateway.
openclaw updateUntuk beralih channel atau menargetkan versi tertentu:
openclaw update --channel betaopenclaw update --channel devopenclaw update --dry-run # pratinjau tanpa menerapkanopenclaw update tidak menerima --verbose. Untuk diagnostik pembaruan, gunakan
--dry-run untuk melihat pratinjau tindakan yang direncanakan, --json untuk hasil terstruktur, atau
openclaw update status --json untuk memeriksa status channel dan ketersediaan. Installer
memiliki flag --verbose sendiri, tetapi flag tersebut bukan bagian dari
openclaw update.
--channel beta memprioritaskan beta, tetapi runtime akan kembali ke stable/latest ketika
tag beta tidak ada atau lebih lama daripada rilis stable terbaru. Gunakan --tag beta
jika Anda menginginkan dist-tag beta npm mentah untuk pembaruan paket satu kali.
Gunakan --channel dev untuk checkout GitHub main bergerak yang persisten. Untuk pembaruan
paket, --tag main dipetakan ke github:openclaw/openclaw#main untuk satu kali jalan, dan
spesifikasi sumber GitHub/git dikemas ke dalam tarball sementara sebelum instalasi npm bertahap.
Untuk Plugin terkelola, fallback channel beta adalah peringatan: pembaruan core masih dapat berhasil sementara Plugin memakai rilis default/latest yang tercatat karena tidak ada beta Plugin yang tersedia.
Lihat Channel pengembangan untuk semantik channel.
Beralih antara instalasi npm dan git
Gunakan channel ketika Anda ingin mengubah jenis instalasi. Updater mempertahankan
state, konfigurasi, kredensial, dan workspace Anda di ~/.openclaw; perintah ini hanya mengubah
instalasi kode OpenClaw mana yang digunakan CLI dan gateway.
# instalasi paket npm -> checkout git yang dapat dieditopenclaw update --channel dev # checkout git -> instalasi paket npmopenclaw update --channel stableJalankan dengan --dry-run terlebih dahulu untuk melihat pratinjau peralihan mode instalasi yang tepat:
openclaw update --channel dev --dry-runopenclaw update --channel stable --dry-runChannel dev memastikan checkout git, membangunnya, dan menginstal CLI global
dari checkout tersebut. Channel stable dan beta menggunakan instalasi paket. Jika
gateway sudah terpasang, openclaw update menyegarkan metadata layanan
dan memulai ulang layanan kecuali Anda meneruskan --no-restart.
Untuk instalasi paket dengan layanan Gateway terkelola, openclaw update menargetkan
root paket yang digunakan oleh layanan tersebut. Jika perintah shell openclaw berasal
dari instalasi berbeda, updater mencetak kedua root dan path Node layanan terkelola.
Pembaruan paket menggunakan package manager yang memiliki root layanan
dan memeriksa Node layanan terkelola terhadap engine rilis target
sebelum mengganti paket.
Alternatif: jalankan ulang installer
curl -fsSL https://openclaw.ai/install.sh | bashTambahkan --no-onboard untuk melewati onboarding. Untuk memaksa jenis instalasi tertentu melalui
installer, teruskan --install-method git --no-onboard atau
--install-method npm --no-onboard.
Jika openclaw update gagal setelah fase instalasi paket npm, jalankan ulang
installer. Installer tidak memanggil updater lama; ia menjalankan instalasi
paket global secara langsung dan dapat memulihkan instalasi npm yang diperbarui sebagian.
curl -fsSL https://openclaw.ai/install.sh | bash -s -- --install-method npmUntuk menyematkan pemulihan ke versi atau dist-tag tertentu, tambahkan --version:
curl -fsSL https://openclaw.ai/install.sh | bash -s -- --install-method npm --version <version-or-dist-tag>Alternatif: npm, pnpm, atau bun manual
npm i -g openclaw@latestUtamakan openclaw update untuk instalasi tersupervisi karena perintah ini dapat mengoordinasikan
pergantian paket dengan layanan Gateway yang sedang berjalan. Jika Anda memperbarui secara manual pada
instalasi tersupervisi, hentikan Gateway terkelola sebelum package manager dimulai.
Package manager mengganti file di tempat, dan Gateway yang sedang berjalan jika tidak dapat mencoba
memuat file core atau Plugin saat pohon paket untuk sementara baru terganti sebagian.
Mulai ulang Gateway setelah package manager selesai agar layanan mengambil
instalasi baru.
Untuk instalasi global sistem Linux milik root, jika openclaw update gagal dengan
EACCES dan Anda memulihkan dengan npm sistem, biarkan Gateway berhenti selama
penggantian paket manual. Gunakan flag profil openclaw atau environment yang sama
yang biasanya Anda gunakan untuk Gateway tersebut. Ganti /usr/bin/npm dengan npm sistem
yang memiliki prefix global milik root di host Anda:
openclaw gateway stopsudo /usr/bin/npm i -g openclaw@latestopenclaw gateway install --forceopenclaw gateway restartLalu verifikasi layanan:
openclaw --versioncurl -fsS http://127.0.0.1:18789/readyzopenclaw plugins list --jsonopenclaw gateway status --deep --jsonopenclaw doctor --lint --jsonKetika openclaw update mengelola instalasi npm global, perintah ini menginstal target ke
prefix npm sementara terlebih dahulu, memverifikasi inventaris dist paket, lalu menukar
pohon paket bersih ke prefix global sebenarnya. Itu menghindari npm menimpa
paket baru di atas file basi dari paket lama. Jika perintah instalasi gagal,
OpenClaw mencoba ulang sekali dengan --omit=optional. Percobaan ulang itu membantu host tempat
dependensi opsional native tidak dapat dikompilasi, sambil tetap membuat kegagalan awal terlihat
jika fallback juga gagal.
Perintah pembaruan npm dan pembaruan Plugin yang dikelola OpenClaw juga menghapus karantina
min-release-age npm untuk proses turunan npm. npm dapat melaporkan
kebijakan tersebut sebagai cutoff before turunan; keduanya berguna untuk kebijakan karantina
rantai pasok umum, tetapi pembaruan OpenClaw eksplisit berarti "instal rilis OpenClaw yang dipilih sekarang."
pnpm add -g openclaw@latestbun add -g openclaw@latestTopik lanjutan instalasi npm
Pohon paket hanya baca
OpenClaw memperlakukan instalasi global paket sebagai hanya baca saat runtime, bahkan ketika direktori paket global dapat ditulis oleh pengguna saat ini. Instalasi paket Plugin berada di root npm/git milik OpenClaw di bawah direktori konfigurasi pengguna, dan startup Gateway tidak memutasi pohon paket OpenClaw.
Beberapa setup npm Linux menginstal paket global di bawah direktori milik root seperti /usr/lib/node_modules/openclaw. OpenClaw mendukung tata letak tersebut karena perintah instalasi/pembaruan Plugin menulis di luar direktori paket global tersebut.
Unit systemd yang diperkeras
Beri OpenClaw akses tulis ke root konfigurasi/state miliknya agar instalasi Plugin eksplisit, pembaruan Plugin, dan pembersihan doctor dapat mempertahankan perubahannya:
ReadWritePaths=/var/lib/openclaw /home/openclaw/.openclaw /tmpPreflight ruang disk
Sebelum pembaruan paket dan instalasi Plugin eksplisit, OpenClaw mencoba pemeriksaan ruang disk best-effort untuk volume target. Ruang rendah menghasilkan peringatan dengan path yang diperiksa, tetapi tidak memblokir pembaruan karena kuota filesystem, snapshot, dan volume jaringan dapat berubah setelah pemeriksaan. Instalasi package manager aktual dan verifikasi pascainstalasi tetap otoritatif.
Auto-updater
Auto-updater nonaktif secara default. Aktifkan di ~/.openclaw/openclaw.json:
{ update: { channel: "stable", auto: { enabled: true, stableDelayHours: 6, stableJitterHours: 12, betaCheckIntervalHours: 1, }, },}| Channel | Perilaku |
|---|---|
stable |
Menunggu stableDelayHours, lalu menerapkan dengan jitter deterministik di seluruh stableJitterHours (rollout tersebar). |
beta |
Memeriksa setiap betaCheckIntervalHours (default: per jam) dan langsung menerapkan. |
dev |
Tidak ada penerapan otomatis. Gunakan openclaw update secara manual. |
Gateway juga mencatat petunjuk pembaruan saat startup (nonaktifkan dengan update.checkOnStart: false).
Untuk downgrade atau pemulihan insiden, tetapkan OPENCLAW_NO_AUTO_UPDATE=1 di environment gateway untuk memblokir penerapan otomatis bahkan ketika update.auto.enabled dikonfigurasi. Petunjuk pembaruan startup masih dapat berjalan kecuali update.checkOnStart juga dinonaktifkan.
Pembaruan package manager yang diminta melalui handler control-plane Gateway live
tidak mengganti pohon paket di dalam proses Gateway yang sedang berjalan. Pada instalasi
layanan terkelola, Gateway memulai handoff terlepas, keluar, dan membiarkan
jalur CLI normal openclaw update --yes --json menghentikan layanan, mengganti
paket, menyegarkan metadata layanan, memulai ulang, memverifikasi versi dan
keterjangkauan Gateway, serta memulihkan LaunchAgent macOS yang terinstal tetapi belum dimuat
jika memungkinkan. Jika Gateway tidak dapat melakukan handoff tersebut dengan aman, update.run melaporkan
perintah shell aman alih-alih menjalankan package manager dalam proses.
Setelah memperbarui
Jalankan doctor
openclaw doctorMemigrasikan konfigurasi, mengaudit kebijakan DM, dan memeriksa kesehatan gateway. Detail: Doctor
Mulai ulang gateway
openclaw gateway restartVerifikasi
openclaw healthRollback
Sematkan versi (npm)
npm i -g openclaw@<version>openclaw doctoropenclaw gateway restartSematkan commit (sumber)
git fetch origingit checkout "$(git rev-list -n 1 --before=\"2026-01-01\" origin/main)"pnpm install && pnpm buildopenclaw gateway restartUntuk kembali ke terbaru: git checkout main && git pull.
Jika Anda buntu
- Jalankan
openclaw doctorlagi dan baca output dengan saksama. - Untuk
openclaw update --channel devpada checkout sumber, updater melakukan bootstrap otomatispnpmsaat diperlukan. Jika Anda melihat error bootstrap pnpm/corepack, instalpnpmsecara manual (atau aktifkan kembalicorepack) dan jalankan ulang pembaruan. - Periksa: Pemecahan masalah
- Tanyakan di Discord: https://discord.gg/clawd
Terkait
- Ikhtisar instalasi: semua metode instalasi.
- Doctor: pemeriksaan kesehatan setelah pembaruan.
- Migrasi: panduan migrasi versi mayor.