Concepts and configuration
CLI Model
Rotasi profil autentikasi, masa tunggu, dan bagaimana itu berinteraksi dengan cadangan.
Ringkasan singkat penyedia dan contoh.
OpenClaw, Codex, dan runtime loop agen lainnya.
Kunci konfigurasi model.
Ref model memilih penyedia dan model. Biasanya ref tersebut tidak memilih runtime agen tingkat rendah. Ref agen OpenAI adalah pengecualian utama: openai/gpt-5.5 berjalan melalui runtime app-server Codex secara default pada penyedia OpenAI resmi. Ref Copilot langganan (github-copilot/*) juga dapat diikutkan ke Plugin runtime agen GitHub Copilot eksternal — jalur itu tetap eksplisit (tanpa cadangan auto). Penggantian runtime eksplisit berada pada kebijakan penyedia/model, bukan pada seluruh agen atau sesi. Dalam mode runtime Codex, ref openai/gpt-* tidak menyiratkan penagihan kunci API; autentikasi dapat berasal dari akun Codex atau profil OAuth openai. Lihat Runtime agen dan Runtime agen GitHub Copilot.
Cara kerja pemilihan model
OpenClaw memilih model dalam urutan ini:
Model utama
agents.defaults.model.primary (atau agents.defaults.model).
Cadangan
agents.defaults.model.fallbacks (berurutan).
Failover autentikasi penyedia
Failover autentikasi terjadi di dalam penyedia sebelum berpindah ke model berikutnya.
Permukaan model terkait
agents.defaults.modelsadalah daftar izin/katalog model yang dapat digunakan OpenClaw (ditambah alias). Gunakan entriprovider/*untuk membatasi penyedia yang terlihat sambil mempertahankan penemuan penyedia tetap dinamis.agents.defaults.imageModeldigunakan hanya ketika model utama tidak dapat menerima gambar.agents.defaults.pdfModeldigunakan oleh alatpdf. Jika dihilangkan, alat kembali keagents.defaults.imageModel, lalu model sesi/default yang di-resolve.agents.defaults.imageGenerationModeldigunakan oleh kapabilitas pembuatan gambar bersama. Jika dihilangkan,image_generatetetap dapat menyimpulkan default penyedia yang didukung autentikasi. Ia mencoba penyedia default saat ini terlebih dahulu, lalu sisa penyedia pembuatan gambar terdaftar dalam urutan ID penyedia. Jika Anda menetapkan penyedia/model tertentu, konfigurasikan juga autentikasi/kunci API penyedia tersebut.agents.defaults.musicGenerationModeldigunakan oleh kapabilitas pembuatan musik bersama. Jika dihilangkan,music_generatetetap dapat menyimpulkan default penyedia yang didukung autentikasi. Ia mencoba penyedia default saat ini terlebih dahulu, lalu sisa penyedia pembuatan musik terdaftar dalam urutan ID penyedia. Jika Anda menetapkan penyedia/model tertentu, konfigurasikan juga autentikasi/kunci API penyedia tersebut.agents.defaults.videoGenerationModeldigunakan oleh kapabilitas pembuatan video bersama. Jika dihilangkan,video_generatetetap dapat menyimpulkan default penyedia yang didukung autentikasi. Ia mencoba penyedia default saat ini terlebih dahulu, lalu sisa penyedia pembuatan video terdaftar dalam urutan ID penyedia. Jika Anda menetapkan penyedia/model tertentu, konfigurasikan juga autentikasi/kunci API penyedia tersebut.- Default per agen dapat mengganti
agents.defaults.modelmelaluiagents.list[].modelplus binding (lihat Perutean multi-agen).
Sumber pemilihan dan perilaku cadangan
provider/model yang sama dapat berarti hal berbeda tergantung dari mana asalnya:
- Default yang dikonfigurasi (
agents.defaults.model.primarydan utama khusus agen) adalah titik awal normal dan menggunakanagents.defaults.model.fallbacks. - Pilihan cadangan otomatis adalah status pemulihan sementara. Pilihan tersebut disimpan dengan
modelOverrideSource: "auto"sehingga giliran berikutnya dapat terus menggunakan rantai cadangan tanpa menguji utama yang diketahui bermasalah setiap kali; OpenClaw secara berkala menguji ulang utama asli, menghapus pilihan otomatis ketika pulih, dan mengumumkan transisi cadangan/pemulihan satu kali per perubahan status. - Pilihan sesi pengguna bersifat eksak.
/model, pemilih model,session_status(model=...), dansessions.patchmenyimpanmodelOverrideSource: "user"; jika penyedia/model yang dipilih itu tidak dapat dijangkau, OpenClaw gagal secara terlihat alih-alih jatuh ke model lain yang dikonfigurasi. - Mengubah
agents.defaults.model.primarytidak menulis ulang pilihan sesi yang ada. Jika status mengatakanThis session is pinned to X; config primary Y will apply to new/unpinned sessions., hapus pilihan sesi saat ini dengan/model defaultagar sesi mewarisi utama yang dikonfigurasi lagi. - Cron
--model/ payloadmodeladalah utama per pekerjaan. Ia tetap menggunakan cadangan yang dikonfigurasi kecuali pekerjaan menyediakan payloadfallbackseksplisit (gunakanfallbacks: []untuk run cron yang ketat). - Pemilih model default CLI dan daftar izin menghormati
models.mode: "replace"dengan mencantumkanmodels.providers.*.modelseksplisit alih-alih memuat katalog bawaan lengkap. - Pemilih model Control UI meminta tampilan model terkonfigurasi kepada Gateway:
agents.defaults.modelssaat ada, termasuk entri seluruh penyediaprovider/*, jika tidak makamodels.providers.*.modelseksplisit plus penyedia dengan autentikasi yang dapat digunakan. Katalog bawaan lengkap dicadangkan untuk tampilan jelajah eksplisit sepertimodels.listdenganview: "all"atauopenclaw models list --all.
Kebijakan model singkat
- Tetapkan utama Anda ke model generasi terbaru terkuat yang tersedia untuk Anda.
- Gunakan cadangan untuk tugas yang sensitif terhadap biaya/latensi dan chat berisiko lebih rendah.
- Untuk agen dengan alat aktif atau input tidak tepercaya, hindari tingkat model yang lebih lama/lebih lemah.
Onboarding (direkomendasikan)
Jika Anda tidak ingin mengedit konfigurasi secara manual, jalankan onboarding:
openclaw onboardIni dapat menyiapkan model + autentikasi untuk penyedia umum, termasuk langganan OpenAI Code (Codex) (OAuth) dan Anthropic (kunci API atau Claude CLI).
Kunci konfigurasi (ringkasan)
agents.defaults.model.primarydanagents.defaults.model.fallbacksagents.defaults.imageModel.primarydanagents.defaults.imageModel.fallbacksagents.defaults.pdfModel.primarydanagents.defaults.pdfModel.fallbacksagents.defaults.imageGenerationModel.primarydanagents.defaults.imageGenerationModel.fallbacksagents.defaults.videoGenerationModel.primarydanagents.defaults.videoGenerationModel.fallbacksagents.defaults.models(daftar izin + alias + parameter penyedia + entri penyedia dinamisprovider/*)models.providers(penyedia kustom yang ditulis kemodels.json)
Edit daftar izin yang aman
Gunakan penulisan aditif saat memperbarui agents.defaults.models secara manual:
openclaw config set agents.defaults.models '{"openai/gpt-5.4":{}}' --strict-json --mergeAturan perlindungan penimpaan
openclaw config set melindungi peta model/penyedia dari penimpaan tidak sengaja. Penetapan objek biasa ke agents.defaults.models, models.providers, atau models.providers.<id>.models ditolak ketika itu akan menghapus entri yang ada. Gunakan --merge untuk perubahan aditif; gunakan --replace hanya ketika nilai yang diberikan harus menjadi nilai target lengkap.
Penyiapan penyedia interaktif dan openclaw configure --section model juga menggabungkan pilihan dengan cakupan penyedia ke daftar izin yang ada, sehingga menambahkan Codex, Ollama, atau penyedia lain tidak menghapus entri model yang tidak terkait. Configure mempertahankan agents.defaults.model.primary yang ada ketika autentikasi penyedia diterapkan ulang. Perintah penetapan default eksplisit seperti openclaw models auth login --provider <id> --set-default dan openclaw models set <model> tetap mengganti agents.defaults.model.primary.
"Model tidak diizinkan" (dan mengapa balasan berhenti)
Jika agents.defaults.models ditetapkan, itu menjadi daftar izin untuk /model dan penggantian sesi. Saat pengguna memilih model yang tidak ada dalam daftar izin itu, OpenClaw mengembalikan:
Model "provider/model" is not allowed. Use /models to list providers, or /models <provider> to list models.Add it with: openclaw config set agents.defaults.models '{"provider/model":{}}' --strict-json --mergeKetika perintah yang ditolak menyertakan penggantian runtime seperti /model openai/gpt-5.5 --runtime codex, perbaiki daftar izin terlebih dahulu, lalu coba ulangi perintah /model ... --runtime ... yang sama. Untuk eksekusi Codex native, model yang dipilih tetap openai/gpt-5.5; runtime codex memilih harness dan menggunakan autentikasi Codex secara terpisah.
Untuk model lokal/GGUF, simpan ref lengkap dengan prefiks penyedia di daftar izin,
misalnya ollama/gemma4:26b, lmstudio/Gemma4-26b-a4-it-gguf, atau
penyedia/model eksak yang ditampilkan oleh openclaw models list --provider <provider>.
Nama file lokal polos atau nama tampilan tidak cukup saat daftar izin
aktif.
Jika Anda ingin membatasi penyedia tanpa mencantumkan setiap model secara manual, tambahkan
entri provider/* ke agents.defaults.models:
{ agents: { defaults: { models: { "openai/*": {}, "vllm/*": {}, }, }, },}Dengan kebijakan itu, /model, /models, dan pemilih model menampilkan
katalog yang ditemukan hanya untuk penyedia tersebut. Model baru dari penyedia yang dipilih dapat
muncul tanpa mengedit daftar izin. Entri provider/model eksak dapat dicampur
dengan entri provider/* saat Anda membutuhkan satu model tertentu dari penyedia lain.
Contoh konfigurasi daftar izin:
{ agents: { defaults: { model: { primary: "anthropic/claude-sonnet-4-6" }, models: { "anthropic/claude-sonnet-4-6": { alias: "Sonnet" }, "anthropic/claude-opus-4-6": { alias: "Opus" }, }, }, },}Beralih model di chat (/model)
Anda dapat beralih model untuk sesi saat ini tanpa memulai ulang:
/model/model list/model 3/model openai/gpt-5.4/model default/model statusPerilaku pemilih
/model(dan/model list) adalah pemilih ringkas bernomor (keluarga model + penyedia yang tersedia).- Di Discord,
/modeldan/modelsmembuka pemilih interaktif dengan dropdown penyedia dan model plus langkah Submit. - Di Telegram, pilihan pemilih
/modelsbercakupan sesi; pilihan tersebut tidak mengubah default persisten agen diopenclaw.json. /models addsudah tidak digunakan dan sekarang mengembalikan pesan deprekasi alih-alih mendaftarkan model dari chat./model <#>memilih dari pemilih tersebut.
Persistensi dan peralihan langsung
/modelsegera menyimpan pilihan sesi baru.- Jika agen sedang menganggur, proses berikutnya langsung menggunakan model baru.
- Jika proses sudah aktif, OpenClaw menandai peralihan langsung sebagai tertunda dan hanya memulai ulang ke model baru pada titik percobaan ulang yang bersih.
- Jika aktivitas alat atau keluaran balasan sudah dimulai, peralihan yang tertunda dapat tetap mengantre sampai kesempatan percobaan ulang berikutnya atau giliran pengguna berikutnya.
/model defaultmenghapus pilihan sesi dan mengembalikan sesi ke model default yang dikonfigurasi.- Ref
/modelyang dipilih pengguna bersifat ketat untuk sesi tersebut: jika penyedia/model yang dipilih tidak dapat dijangkau, balasan gagal secara terlihat alih-alih diam-diam menjawab dariagents.defaults.model.fallbacks. Ini berbeda dari default yang dikonfigurasi dan primer tugas cron, yang masih dapat menggunakan rantai fallback. /model statusadalah tampilan terperinci (kandidat auth dan, bila dikonfigurasi, endpoint penyediabaseUrl+ modeapi).
Penguraian ref
- Ref model diuraikan dengan memisahkan pada
/pertama. Gunakanprovider/modelsaat mengetik/model <ref>. - Jika ID model itu sendiri berisi
/(gaya OpenRouter), Anda harus menyertakan prefiks penyedia (contoh:/model openrouter/moonshotai/kimi-k2). - Jika Anda menghilangkan penyedia, OpenClaw menyelesaikan input dalam urutan ini:
- kecocokan alias
- kecocokan penyedia terkonfigurasi yang unik untuk id model tanpa prefiks yang persis sama
- fallback usang ke penyedia default yang dikonfigurasi — jika penyedia itu tidak lagi mengekspos model default yang dikonfigurasi, OpenClaw sebagai gantinya fallback ke penyedia/model terkonfigurasi pertama untuk menghindari memunculkan default penyedia yang dihapus dan basi.
Perilaku/konfigurasi perintah lengkap: Perintah slash.
Perintah CLI
openclaw models listopenclaw models statusopenclaw models set <provider/model>openclaw models set-image <provider/model> openclaw models aliases listopenclaw models aliases add <alias> <provider/model>openclaw models aliases remove <alias> openclaw models fallbacks listopenclaw models fallbacks add <provider/model>openclaw models fallbacks remove <provider/model>openclaw models fallbacks clear openclaw models image-fallbacks listopenclaw models image-fallbacks add <provider/model>openclaw models image-fallbacks remove <provider/model>openclaw models image-fallbacks clearopenclaw models (tanpa subperintah) adalah pintasan untuk models status.
models list
Menampilkan model yang dikonfigurasi/tersedia-auth secara default. Flag yang berguna:
--allbooleanKatalog lengkap. Menyertakan baris katalog statis bawaan milik penyedia sebelum auth dikonfigurasi, sehingga tampilan khusus penemuan dapat menampilkan model yang tidak tersedia sampai Anda menambahkan kredensial penyedia yang cocok.
--localbooleanHanya penyedia lokal.
OPENCLAW_DOCS_MARKER:paramOpen:IHBhdGg9Ii0tcHJvdmlkZXIgPGlk
" type="string">
Filter berdasarkan id penyedia, misalnya moonshot. Label tampilan dari pemilih interaktif tidak diterima.
--plainbooleanSatu model per baris.
--jsonbooleanKeluaran yang dapat dibaca mesin.
models status
Menampilkan model primer yang diselesaikan, fallback, model gambar, dan ringkasan auth dari penyedia yang dikonfigurasi. Ini juga memunculkan status kedaluwarsa OAuth untuk profil yang ditemukan di penyimpanan auth (memperingatkan dalam 24 jam secara default). --plain hanya mencetak model primer yang diselesaikan.
Perilaku auth dan probe
- Status OAuth selalu ditampilkan (dan disertakan dalam keluaran
--json). Jika penyedia yang dikonfigurasi tidak memiliki kredensial,models statusmencetak bagian Auth hilang. - JSON menyertakan
auth.oauth(jendela peringatan + profil) danauth.providers(auth efektif per penyedia, termasuk kredensial berbasis env).auth.oauthhanya kesehatan profil penyimpanan-auth; penyedia yang hanya env tidak muncul di sana. - Gunakan
--checkuntuk otomatisasi (keluar1saat hilang/kedaluwarsa,2saat hampir kedaluwarsa). - Gunakan
--probeuntuk pemeriksaan auth langsung; baris probe dapat berasal dari profil auth, kredensial env, ataumodels.json. - Jika
auth.order.<provider>eksplisit menghilangkan profil tersimpan, probe melaporkanexcluded_by_auth_orderalih-alih mencobanya. Jika auth ada tetapi tidak ada model yang dapat diprobe yang dapat diselesaikan untuk penyedia itu, probe melaporkanstatus: no_model.
Contoh (Claude CLI):
claude auth loginopenclaw models statusPemindaian (model gratis OpenRouter)
openclaw models scan memeriksa katalog model gratis OpenRouter dan secara opsional dapat memprobe model untuk dukungan alat dan gambar.
--no-probebooleanLewati probe langsung (hanya metadata).
"--min-params"--max-age-days"--provider"--max-candidates--set-defaultbooleanAtur agents.defaults.model.primary ke pilihan pertama.
--set-imagebooleanAtur agents.defaults.imageModel.primary ke pilihan gambar pertama.
Hasil pemindaian diberi peringkat berdasarkan:
- Dukungan gambar
- Latensi alat
- Ukuran konteks
- Jumlah parameter
Input:
- Daftar
/modelsOpenRouter (filter:free) - Probe langsung memerlukan kunci API OpenRouter dari profil auth atau
OPENROUTER_API_KEY(lihat Variabel lingkungan) - Filter opsional:
--max-age-days,--min-params,--provider,--max-candidates - Kontrol permintaan/probe:
--timeout,--concurrency
Saat probe langsung berjalan di TUI, Anda dapat memilih fallback secara interaktif. Dalam mode non-interaktif, berikan --yes untuk menerima default. Hasil hanya metadata bersifat informatif; --set-default dan --set-image memerlukan probe langsung agar OpenClaw tidak mengonfigurasi model OpenRouter tanpa kunci yang tidak dapat digunakan.
Registri model (models.json)
Penyedia kustom di models.providers ditulis ke models.json di bawah direktori agen (default ~/.openclaw/agents/<agentId>/agent/models.json). Katalog Plugin penyedia disimpan sebagai shard katalog yang dihasilkan dan dimiliki plugin di bawah state plugin agen dan dimuat otomatis. File ini digabungkan secara default kecuali models.mode diatur ke replace.
Prioritas mode gabung
Prioritas mode gabung untuk ID penyedia yang cocok:
baseUrltidak kosong yang sudah ada dimodels.jsonagen menang.apiKeytidak kosong dimodels.jsonagen hanya menang ketika penyedia itu tidak dikelola SecretRef dalam konteks konfigurasi/profil-auth saat ini.- Nilai
apiKeypenyedia yang dikelola SecretRef disegarkan dari marker sumber (ENV_VAR_NAMEuntuk ref env,secretref-manageduntuk ref file/exec) alih-alih mempertahankan rahasia yang telah diselesaikan. - Nilai header penyedia yang dikelola SecretRef disegarkan dari marker sumber (
secretref-env:ENV_VAR_NAMEuntuk ref env,secretref-manageduntuk ref file/exec). apiKey/baseUrlagen yang kosong atau hilang fallback kemodels.providerskonfigurasi.- Field penyedia lainnya disegarkan dari konfigurasi dan data katalog yang dinormalisasi.
Terkait
- Runtime agen — OpenClaw, Codex, dan runtime loop agen lainnya
- Referensi konfigurasi — kunci konfigurasi model
- Pembuatan gambar — konfigurasi model gambar
- Failover model — rantai fallback
- Penyedia model — routing penyedia dan auth
- Pembuatan musik — konfigurasi model musik
- Pembuatan video — konfigurasi model video