Fundamentals
Mesin konteks
Sebuah mesin konteks mengontrol cara OpenClaw membangun konteks model untuk setiap run: pesan mana yang akan disertakan, cara meringkas riwayat lama, dan cara mengelola konteks melintasi batas subagen.
OpenClaw menyertakan mesin bawaan legacy dan menggunakannya secara default - sebagian besar pengguna tidak perlu mengubah ini. Instal dan pilih mesin plugin hanya ketika Anda menginginkan perilaku perakitan, Compaction, atau pengingatan lintas-sesi yang berbeda.
Mulai cepat
Periksa mesin mana yang aktif
openclaw doctor# atau periksa config secara langsung:cat ~/.openclaw/openclaw.json | jq '.plugins.slots.contextEngine'Instal mesin plugin
Plugin mesin konteks diinstal seperti Plugin OpenClaw lainnya.
Dari npm
openclaw plugins install @martian-engineering/lossless-clawDari path lokal
openclaw plugins install -l ./my-context-engineAktifkan dan pilih mesin
// openclaw.json{ plugins: { slots: { contextEngine: "lossless-claw", // must match the plugin's registered engine id }, entries: { "lossless-claw": { enabled: true, // Plugin-specific config goes here (see the plugin's docs) }, }, },}Mulai ulang gateway setelah menginstal dan mengonfigurasi.
Beralih kembali ke legacy (opsional)
Atur contextEngine ke "legacy" (atau hapus kunci sepenuhnya - "legacy" adalah default).
Cara kerjanya
Setiap kali OpenClaw menjalankan prompt model, mesin konteks berpartisipasi pada empat titik siklus hidup:
1. Ingest
Dipanggil saat pesan baru ditambahkan ke sesi. Mesin dapat menyimpan atau mengindeks pesan dalam penyimpanan datanya sendiri.
2. Assemble
Dipanggil sebelum setiap run model. Mesin mengembalikan sekumpulan pesan berurutan (dan systemPromptAddition opsional) yang muat dalam anggaran token.
3. Compact
Dipanggil saat jendela konteks penuh, atau saat pengguna menjalankan /compact. Mesin meringkas riwayat lama untuk mengosongkan ruang.
4. After turn
Dipanggil setelah sebuah run selesai. Mesin dapat mempertahankan state, memicu Compaction latar belakang, atau memperbarui indeks.
Untuk harness Codex non-ACP yang dibundel, OpenClaw menerapkan siklus hidup yang sama dengan memproyeksikan konteks yang dirakit ke dalam instruksi developer Codex dan prompt giliran saat ini. Codex tetap memiliki riwayat thread native dan compactor native-nya sendiri.
Siklus hidup subagen (opsional)
OpenClaw memanggil dua hook siklus hidup subagen opsional:
prepareSubagentSpawnmethodMenyiapkan state konteks bersama sebelum run anak dimulai. Hook menerima kunci sesi induk/anak, contextMode (isolated atau fork), id/file transkrip yang tersedia, dan TTL opsional. Jika mengembalikan handle rollback, OpenClaw memanggilnya ketika spawn gagal setelah persiapan berhasil. Spawn subagen native yang meminta lightContext dan terselesaikan menjadi contextMode="isolated" sengaja melewati hook ini agar anak dimulai dari konteks bootstrap ringan tanpa state pra-spawn yang dikelola mesin konteks.
onSubagentEndedmethodMembersihkan saat sesi subagen selesai atau disapu.
Tambahan prompt sistem
Metode assemble dapat mengembalikan string systemPromptAddition. OpenClaw menambahkan ini di awal prompt sistem untuk run tersebut. Ini memungkinkan mesin menyuntikkan panduan pengingatan dinamis, instruksi retrieval, atau petunjuk sadar konteks tanpa memerlukan file workspace statis.
Mesin legacy
Mesin bawaan legacy mempertahankan perilaku asli OpenClaw:
- Ingest: no-op (manajer sesi menangani persistensi pesan secara langsung).
- Assemble: pass-through (pipeline sanitize → validate → limit yang ada di runtime menangani perakitan konteks).
- Compact: mendelegasikan ke Compaction peringkasan bawaan, yang membuat satu ringkasan pesan lama dan menjaga pesan terbaru tetap utuh.
- After turn: no-op.
Mesin legacy tidak mendaftarkan tool atau menyediakan systemPromptAddition.
Ketika tidak ada plugins.slots.contextEngine yang ditetapkan (atau ditetapkan ke "legacy"), mesin ini digunakan secara otomatis.
Mesin plugin
Sebuah plugin dapat mendaftarkan mesin konteks menggunakan API plugin:
export default function register(api) { api.registerContextEngine("my-engine", (ctx) => ({ info: { id: "my-engine", name: "My Context Engine", ownsCompaction: true, }, async ingest({ sessionId, message, isHeartbeat }) { // Store the message in your data store return { ingested: true }; }, async assemble({ sessionId, messages, tokenBudget, availableTools, citationsMode }) { // Return messages that fit the budget return { messages: buildContext(messages, tokenBudget), estimatedTokens: countTokens(messages), systemPromptAddition: buildMemorySystemPromptAddition({ availableTools: availableTools ?? new Set(), citationsMode, }), }; }, async compact({ sessionId, force }) { // Summarize older context return { ok: true, compacted: true }; }, }));}Factory ctx menyertakan nilai config, agentDir, dan workspaceDir
opsional sehingga plugin dapat menginisialisasi state per-agen atau per-workspace sebelum
hook siklus hidup pertama berjalan.
Lalu aktifkan di config:
{ plugins: { slots: { contextEngine: "my-engine", }, entries: { "my-engine": { enabled: true, }, }, },}Antarmuka ContextEngine
Anggota wajib:
| Anggota | Jenis | Tujuan |
|---|---|---|
info |
Properti | Id mesin, nama, versi, dan apakah mesin memiliki Compaction |
ingest(params) |
Metode | Menyimpan satu pesan |
assemble(params) |
Metode | Membangun konteks untuk run model (mengembalikan AssembleResult) |
compact(params) |
Metode | Meringkas/mengurangi konteks |
assemble mengembalikan AssembleResult dengan:
messagesMessage[]requiredPesan berurutan yang akan dikirim ke model.
estimatedTokensnumberrequiredEstimasi mesin atas total token dalam konteks yang dirakit. OpenClaw menggunakan ini untuk keputusan ambang Compaction dan pelaporan diagnostik.
systemPromptAdditionstringDitambahkan di awal prompt sistem.
promptAuthority"assembled" | "preassembly_may_overflow"Mengontrol estimasi token mana yang digunakan runner untuk precheck overflow
preventif. Default ke "assembled", yang berarti hanya estimasi prompt
yang dirakit yang diperiksa untuk mesin yang tidak memiliki Compaction.
Mesin yang menetapkan ownsCompaction: true mengelola admission prompt
mereka sendiri, jadi OpenClaw melewati precheck pra-prompt generik secara default. Tetapkan
"preassembly_may_overflow" hanya ketika tampilan yang dirakit dapat menyembunyikan risiko overflow
dalam transkrip yang mendasarinya; runner kemudian menjaga precheck generik
tetap aktif dan mengambil maksimum dari estimasi yang dirakit dan estimasi
riwayat sesi pra-perakitan (tanpa jendela) saat memutuskan apakah akan
melakukan compact secara preventif. Bagaimanapun, pesan yang Anda kembalikan tetap yang
dilihat model - promptAuthority hanya memengaruhi precheck.
compact mengembalikan CompactResult. Ketika Compaction merotasi transkrip
aktif, result.sessionId dan result.sessionFile mengidentifikasi sesi penerus
yang harus digunakan retry atau giliran berikutnya.
Anggota opsional:
| Anggota | Jenis | Tujuan |
|---|---|---|
bootstrap(params) |
Metode | Menginisialisasi state mesin untuk sebuah sesi. Dipanggil sekali saat mesin pertama kali melihat sesi (mis., mengimpor riwayat). |
ingestBatch(params) |
Metode | Menelan giliran yang selesai sebagai batch. Dipanggil setelah sebuah run selesai, dengan semua pesan dari giliran itu sekaligus. |
afterTurn(params) |
Metode | Pekerjaan siklus hidup pasca-run (mempertahankan state, memicu Compaction latar belakang). |
prepareSubagentSpawn(params) |
Metode | Menyiapkan state bersama untuk sesi anak sebelum dimulai. |
onSubagentEnded(params) |
Metode | Membersihkan setelah subagen berakhir. |
dispose() |
Metode | Melepaskan sumber daya. Dipanggil selama shutdown gateway atau reload plugin - bukan per-sesi. |
Pengaturan runtime
Hook siklus hidup yang berjalan di dalam OpenClaw menerima objek
runtimeSettings opsional. Ini adalah permukaan API produsen/konsumen internal
berversi dan baca-saja: OpenClaw memproduksinya untuk mesin konteks yang dipilih,
dan mesin konteks mengonsumsinya di dalam hook siklus hidup. Ini tidak
dirender langsung kepada pengguna dan tidak membuat permukaan pelaporan khusus.
schemaVersion: saat ini1runtime: host OpenClaw, mode runtime (normal,fallback, ataudegraded), dan id harness/runtime opsionalcontextEngineSelection: id mesin konteks yang dipilih dan sumber pemilihanexecutionHost: id host dan label untuk permukaan yang memanggil hookmodel: model yang diminta, model yang terselesaikan, provider, dan family model opsionallimits: anggaran token prompt dan token output maksimum jika diketahuidiagnostics: kode alasan fallback tertutup dan degraded jika diketahui
Field yang dapat tidak diketahui direpresentasikan sebagai null; field diskriminator seperti
mode runtime dan sumber pemilihan tetap non-nullable. Mesin lama tetap
kompatibel: jika mesin legacy ketat menolak runtimeSettings sebagai properti
tidak dikenal, OpenClaw mencoba ulang panggilan siklus hidup tanpanya alih-alih mengarantina
mesin.
Persyaratan host
Mesin konteks dapat mendeklarasikan persyaratan kapabilitas host pada info.hostRequirements.
OpenClaw memeriksa persyaratan ini sebelum memulai operasi dan gagal tertutup
dengan error deskriptif ketika runtime yang dipilih tidak dapat memenuhinya.
Untuk run agen, deklarasikan assemble-before-prompt ketika mesin harus mengontrol
prompt model aktual melalui assemble():
info: { id: "my-context-engine", name: "My Context Engine", hostRequirements: { "agent-run": { requiredCapabilities: ["assemble-before-prompt"], unsupportedMessage: "Use the native Codex or OpenClaw embedded runtime, or select the legacy context engine.", }, },}Run agen native Codex dan embedded OpenClaw memenuhi assemble-before-prompt.
Backend CLI generik tidak, jadi mesin yang memerlukannya ditolak sebelum
proses CLI dimulai.
Isolasi kegagalan
OpenClaw mengisolasi mesin plugin yang dipilih dari jalur balasan inti. Jika
mesin non-legacy tidak ada, gagal validasi kontrak, melempar error selama
pembuatan factory, atau melempar error dari metode lifecycle, OpenClaw mengarantina mesin tersebut
untuk proses Gateway saat ini dan menurunkan pekerjaan context-engine ke mesin
bawaan legacy. Error dicatat dengan operasi yang gagal sehingga
operator dapat memperbaiki, memperbarui, atau menonaktifkan plugin tanpa agent menjadi
diam.
Kegagalan persyaratan host berbeda: ketika mesin menyatakan bahwa sebuah runtime tidak memiliki capability yang diperlukan, OpenClaw gagal tertutup sebelum memulai run. Hal itu melindungi mesin yang akan merusak state jika dijalankan di host yang tidak didukung.
ownsCompaction
ownsCompaction mengontrol apakah auto-compaction bawaan dalam-attempt milik runtime OpenClaw tetap aktif untuk run tersebut:
ownsCompaction: true
Mesin memiliki perilaku compaction. OpenClaw menonaktifkan auto-compaction bawaan runtime OpenClaw dan precheck overflow pra-prompt generik untuk run tersebut, dan implementasi compact() milik mesin bertanggung jawab atas /compact, compaction pemulihan overflow provider, dan compaction proaktif apa pun yang ingin dilakukan di afterTurn(). OpenClaw tetap menjalankan perlindungan overflow pra-prompt ketika mesin mengembalikan promptAuthority: "preassembly_may_overflow" dari assemble().
ownsCompaction: false or unset
Auto-compaction bawaan runtime OpenClaw masih dapat berjalan selama eksekusi prompt, tetapi metode compact() milik mesin aktif tetap dipanggil untuk /compact dan pemulihan overflow.
Itu berarti ada dua pola plugin yang valid:
Mode memiliki
Implementasikan algoritme compaction Anda sendiri dan tetapkan ownsCompaction: true.
Mode delegasi
Tetapkan ownsCompaction: false dan buat compact() memanggil delegateCompactionToRuntime(...) dari openclaw/plugin-sdk/core untuk menggunakan perilaku compaction bawaan OpenClaw.
compact() no-op tidak aman untuk mesin aktif yang tidak memiliki compaction karena menonaktifkan jalur compaction normal /compact dan pemulihan overflow untuk slot mesin tersebut.
Referensi konfigurasi
{ plugins: { slots: { // Pilih mesin konteks aktif. Default: "legacy". // Tetapkan ke id plugin untuk menggunakan mesin plugin. contextEngine: "legacy", }, },}Hubungan dengan compaction dan memori
Compaction
Compaction adalah salah satu tanggung jawab mesin konteks. Mesin legacy mendelegasikan ke summarization bawaan OpenClaw. Mesin plugin dapat mengimplementasikan strategi compaction apa pun (ringkasan DAG, vector retrieval, dll.).
Plugin memori
Plugin memori (plugins.slots.memory) terpisah dari mesin konteks. Plugin memori menyediakan pencarian/retrieval; mesin konteks mengontrol apa yang dilihat model. Keduanya dapat bekerja bersama - mesin konteks mungkin menggunakan data plugin memori selama assembly. Mesin plugin yang menginginkan jalur prompt memori aktif sebaiknya memilih buildMemorySystemPromptAddition(...) dari openclaw/plugin-sdk/core, yang mengonversi bagian prompt memori aktif menjadi systemPromptAddition siap-ditambahkan-di-awal. Jika mesin membutuhkan kontrol tingkat lebih rendah, mesin masih dapat mengambil baris mentah dari openclaw/plugin-sdk/memory-host-core melalui buildActiveMemoryPromptSection(...).
Pemangkasan sesi
Pemangkasan hasil tool lama di memori tetap berjalan terlepas dari mesin konteks mana yang aktif.
Tips
- Gunakan
openclaw doctoruntuk memverifikasi mesin Anda dimuat dengan benar. - Jika mengganti mesin, sesi yang ada berlanjut dengan riwayatnya saat ini. Mesin baru mengambil alih untuk run mendatang.
- Error mesin dicatat dan mesin plugin yang dipilih dikarantina untuk proses Gateway saat ini. OpenClaw fallback ke
legacyuntuk giliran pengguna agar balasan dapat berlanjut, tetapi Anda tetap harus memperbaiki, memperbarui, menonaktifkan, atau menghapus plugin yang rusak. - Untuk pengembangan, gunakan
openclaw plugins install -l ./my-engineuntuk menautkan direktori plugin lokal tanpa menyalin.
Terkait
- Compaction - meringkas percakapan panjang
- Konteks - bagaimana konteks dibangun untuk giliran agent
- Arsitektur Plugin - mendaftarkan plugin mesin konteks
- Manifest plugin - field manifest plugin
- Plugin - gambaran umum plugin