Pembantu debugging untuk output streaming, terutama ketika provider mencampur reasoning ke dalam teks normal.Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Override debug runtime
Gunakan/debug dalam chat untuk menetapkan override konfigurasi khusus runtime (memori, bukan disk).
/debug dinonaktifkan secara default; aktifkan dengan commands.debug: true.
Ini berguna ketika Anda perlu mengaktifkan atau menonaktifkan pengaturan yang kurang umum tanpa mengedit openclaw.json.
Contoh:
/debug reset menghapus semua override dan kembali ke konfigurasi di disk.
Output trace sesi
Gunakan/trace ketika Anda ingin melihat baris trace/debug milik plugin dalam satu sesi
tanpa mengaktifkan mode verbose penuh.
Contoh:
/trace untuk diagnostik plugin seperti ringkasan debug Active Memory.
Tetap gunakan /verbose untuk status/output tool verbose normal, dan tetap gunakan
/debug untuk override konfigurasi khusus runtime.
Trace siklus hidup Plugin
GunakanOPENCLAW_PLUGIN_LIFECYCLE_TRACE=1 ketika perintah siklus hidup plugin terasa lambat
dan Anda memerlukan rincian fase bawaan untuk metadata plugin, penemuan, registry,
mirror runtime, mutasi konfigurasi, dan pekerjaan refresh. Trace ini opt-in dan menulis
ke stderr, sehingga output perintah JSON tetap dapat diurai.
Contoh:
node dist/entry.js ... setelah pnpm build; pnpm openclaw ...
juga mengukur overhead source-runner.
Startup CLI dan profiling perintah
Gunakan benchmark startup yang sudah disertakan ketika sebuah perintah terasa lambat:OPENCLAW_RUN_NODE_CPU_PROF_DIR:
.cpuprofile untuk
perintah tersebut. Gunakan ini sebelum menambahkan instrumentasi sementara ke kode perintah.
Untuk hambatan startup yang tampak seperti pekerjaan filesystem sinkron atau module-loader,
tambahkan flag trace I/O sinkron Node melalui source runner:
pnpm gateway:watch membiarkan flag ini dinonaktifkan secara default untuk child
Gateway yang dipantau. Tetapkan OPENCLAW_TRACE_SYNC_IO=1 ketika Anda secara eksplisit menginginkan
output trace I/O sinkron Node dalam mode watch.
Mode watch Gateway
Untuk iterasi cepat, jalankan gateway di bawah file watcher:openclaw-gateway-watch-main (atau varian spesifik profil/port seperti
openclaw-gateway-watch-dev-19001) dan otomatis melampirkan dari terminal interaktif.
Shell noninteraktif, CI, dan panggilan exec agen tetap detached dan mencetak instruksi attach
sebagai gantinya. Attach secara manual bila diperlukan:
--benchmark sebelum memanggil Gateway dan menulis
satu .cpuprofile V8 per child Gateway yang keluar di bawah
.artifacts/gateway-watch-profiles/. Hentikan atau mulai ulang gateway yang dipantau untuk
mem-flush profil saat ini, lalu buka dengan Chrome DevTools atau Speedscope:
--benchmark-dir <path> ketika Anda menginginkan profil di tempat lain.
Gunakan --benchmark-no-force ketika Anda ingin child yang di-benchmark melewati
pembersihan port default --force dan gagal cepat jika port Gateway sudah digunakan.
Mode benchmark menekan spam trace sync-I/O secara default. Tetapkan
OPENCLAW_TRACE_SYNC_IO=1 dengan --benchmark ketika Anda secara eksplisit menginginkan profil CPU
dan stack trace sync-I/O Node. Dalam mode benchmark, blok trace tersebut
ditulis ke gateway-watch-output.log di bawah direktori benchmark dan
difilter dari pane terminal; log Gateway normal tetap terlihat.
Wrapper tmux membawa selector runtime non-rahasia umum seperti
OPENCLAW_PROFILE, OPENCLAW_CONFIG_PATH, OPENCLAW_STATE_DIR,
OPENCLAW_GATEWAY_PORT, dan OPENCLAW_SKIP_CHANNELS ke dalam pane. Letakkan
kredensial provider dalam profil/konfigurasi normal Anda, atau gunakan mode foreground mentah
untuk rahasia ephemeral sekali pakai.
Jika Gateway yang dipantau keluar selama startup, watcher menjalankan
openclaw doctor --fix --non-interactive sekali dan memulai ulang child Gateway.
Gunakan OPENCLAW_GATEWAY_WATCH_AUTO_DOCTOR=0 ketika Anda menginginkan kegagalan startup
asli tanpa pass perbaikan khusus dev.
Pane tmux terkelola juga default ke log Gateway berwarna agar mudah dibaca;
tetapkan FORCE_COLOR=0 saat memulai pnpm gateway:watch untuk menonaktifkan output ANSI.
Watcher memulai ulang pada file yang relevan untuk build di bawah src/, file sumber extension,
metadata package.json dan openclaw.plugin.json extension, tsconfig.json,
package.json, dan tsdown.config.ts. Perubahan metadata extension memulai ulang
gateway tanpa memaksa rebuild tsdown; perubahan sumber dan konfigurasi tetap
membangun ulang dist terlebih dahulu.
Tambahkan flag CLI gateway apa pun setelah gateway:watch dan flag itu akan diteruskan pada
setiap restart. Menjalankan ulang perintah watch yang sama akan mem-spawn ulang pane tmux bernama tersebut, dan
watcher mentah tetap menjaga lock single-watcher-nya sehingga parent watcher duplikat
diganti, bukan menumpuk.
Profil dev + gateway dev (—dev)
Gunakan profil dev untuk mengisolasi state dan menjalankan setup aman yang dapat dibuang untuk debugging. Ada dua flag--dev:
- Global
--dev(profil): mengisolasi state di bawah~/.openclaw-devdan menetapkan port gateway default ke19001(port turunan ikut bergeser). gateway --dev: memberi tahu Gateway untuk otomatis membuat konfigurasi default + workspace ketika belum ada (dan melewati BOOTSTRAP.md).
pnpm openclaw ....
Yang dilakukan ini:
-
Isolasi profil (global
--dev)OPENCLAW_PROFILE=devOPENCLAW_STATE_DIR=~/.openclaw-devOPENCLAW_CONFIG_PATH=~/.openclaw-dev/openclaw.jsonOPENCLAW_GATEWAY_PORT=19001(browser/canvas bergeser sesuai itu)
-
Bootstrap dev (
gateway --dev)- Menulis konfigurasi minimal jika belum ada (
gateway.mode=local, bind loopback). - Menetapkan
agent.workspaceke workspace dev. - Menetapkan
agent.skipBootstrap=true(tanpa BOOTSTRAP.md). - Menyemai file workspace jika belum ada:
AGENTS.md,SOUL.md,TOOLS.md,IDENTITY.md,USER.md,HEARTBEAT.md. - Identitas default: C3-PO (droid protokol).
- Melewati provider channel dalam mode dev (
OPENCLAW_SKIP_CHANNELS=1).
- Menulis konfigurasi minimal jika belum ada (
--dev adalah flag profil global dan dikonsumsi oleh beberapa runner. Jika Anda perlu menuliskannya secara eksplisit, gunakan bentuk env var:--reset menghapus konfigurasi, kredensial, sesi, dan workspace dev (menggunakan
trash, bukan rm), lalu membuat ulang setup dev default.
Logging stream mentah (OpenClaw)
OpenClaw dapat mencatat stream assistant mentah sebelum filtering/formatting apa pun. Ini adalah cara terbaik untuk melihat apakah reasoning tiba sebagai delta teks biasa (atau sebagai blok berpikir terpisah). Aktifkan melalui CLI:~/.openclaw/logs/raw-stream.jsonl
Logging chunk mentah (pi-mono)
Untuk menangkap chunk kompatibel OpenAI mentah sebelum diurai menjadi blok, pi-mono mengekspos logger terpisah:~/.pi-mono/logs/raw-openai-completions.jsonl
Catatan: ini hanya dikeluarkan oleh proses yang menggunakan provider
openai-completions milik pi-mono.
Catatan keamanan
- Log stream mentah dapat menyertakan prompt lengkap, output tool, dan data pengguna.
- Simpan log secara lokal dan hapus setelah debugging.
- Jika Anda membagikan log, bersihkan rahasia dan PII terlebih dahulu.
Debugging di VSCode
Source map diperlukan untuk mengaktifkan debugging di IDE berbasis VSCode karena banyak file yang dihasilkan berakhir dengan nama hash sebagai bagian dari proses build. Konfigurasilaunch.json yang disertakan menargetkan layanan Gateway, tetapi dapat diadaptasi dengan cepat untuk tujuan lain:
- Rebuild and Debug Gateway - Men-debug layanan Gateway setelah membuat build baru
- Debug Gateway - Men-debug layanan Gateway dari build yang sudah ada
Setup
Konfigurasi default Rebuild and Debug Gateway sudah lengkap, konfigurasi ini akan otomatis menghapus folder/dist dan membangun ulang proyek dengan debugging diaktifkan:
- Buka panel Run and Debug dari Activity Bar atau tekan
Ctrl+Shift+D - Di IDE, pastikan Rebuild and Debug Gateway dipilih di dropdown konfigurasi lalu tekan tombol Start Debugging
- Buka terminal dan aktifkan source map:
- Linux/macOS:
export OUTPUT_SOURCE_MAPS=1 - Windows (PowerShell):
$env:OUTPUT_SOURCE_MAPS="1" - Windows (CMD):
set OUTPUT_SOURCE_MAPS=1
- Linux/macOS:
- Di terminal yang sama, build ulang proyek:
pnpm clean:dist && pnpm build - Di IDE, pilih opsi Debug Gateway di dropdown konfigurasi Run and Debug lalu tekan tombol Start Debugging
src/) dan debugger akan memetakan breakpoint dengan benar ke JavaScript terkompilasi melalui source map. Anda akan dapat memeriksa variabel, melangkah melalui kode, dan memeriksa call stack sesuai harapan.
Catatan
- Jika menggunakan opsi “Rebuild and Debug Gateway” - setiap kali debugger diluncurkan, folder
/distakan dihapus sepenuhnya danpnpm buildpenuh dengan source map aktif akan dijalankan sebelum memulai Gateway - Jika menggunakan opsi “Debug Gateway” - sesi debug dapat dimulai dan dihentikan kapan saja tanpa memengaruhi folder
/dist, tetapi Anda harus menggunakan proses terminal terpisah untuk mengaktifkan debugging sekaligus mengelola siklus build - Ubah pengaturan
launch.jsonuntukargsguna men-debug bagian lain dari proyek - Jika Anda perlu menggunakan CLI OpenClaw hasil build untuk tugas lain (misalnya
dashboard --no-openjika sesi debug Anda memunculkan token auth baru), Anda dapat menjalankannya di terminal lain sebagainode ./openclaw.mjsatau membuat alias shell sepertialias openclaw-build="node $(pwd)/openclaw.mjs"