Konfig
Verwenden Sie die Konfiguration OpenCode JSON.
Sie können OpenCode mithilfe einer JSON-Konfigurationsdatei konfigurieren.
Format
OpenCode unterstützt die Formate JSON und JSONC (JSON mit Kommentaren).
{ "$schema": "https://opencode.ai/config.json", // Theme configuration "theme": "opencode", "model": "anthropic/claude-sonnet-4-5", "autoupdate": true,}Locations
Sie können Ihre Konfiguration an verschiedenen Orten platzieren und sie haben eine andere Rangfolge.
Konfigurationsdateien werden zusammengeführt und nicht ersetzt. Einstellungen aus den folgenden Konfigurationsspeicherorten werden kombiniert. Spätere Konfigurationen überschreiben frühere nur bei Schlüsselkonflikten. Es bleiben keine widersprüchlichen Einstellungen aus allen Konfigurationen erhalten.
Wenn Ihre globale Konfiguration beispielsweise theme: "opencode" und autoupdate: true und Ihre Projektkonfiguration model: "anthropic/claude-sonnet-4-5" festlegt, umfasst die endgültige Konfiguration alle drei Einstellungen.
Rangfolge
Konfigurationsquellen werden in dieser Reihenfolge geladen (spätere Quellen überschreiben frühere):
- Remote-Konfiguration (von
.well-known/opencode) – Organisationsstandards - Globale Konfiguration (
~/.config/opencode/opencode.json) – Benutzereinstellungen - Benutzerdefinierte Konfiguration (
OPENCODE_CONFIGenv var) – benutzerdefinierte Überschreibungen - Projektkonfiguration (
opencode.jsonim Projekt) – projektspezifische Einstellungen .opencodeVerzeichnisse – Agenten, Befehle, Plugins- Inline-Konfiguration (
OPENCODE_CONFIG_CONTENTenv var) – Laufzeitüberschreibungen
Dies bedeutet, dass Projektkonfigurationen globale Standardeinstellungen überschreiben können und globale Konfigurationen Remote-Organisationsstandards überschreiben können.
Remote
Organisationen können die Standardkonfiguration über den Endpunkt .well-known/opencode bereitstellen. Dieser wird automatisch abgerufen, wenn Sie sich bei einem Anbieter authentifizieren, der dies unterstützt.
Zuerst wird die Remote-Konfiguration geladen, die als Basisschicht dient. Alle anderen Konfigurationsquellen (global, Projekt) können diese Standardeinstellungen überschreiben.
Wenn Ihre Organisation beispielsweise MCP-Server bereitstellt, sind die standardmäßig deaktiviert:
{ "mcp": { "jira": { "type": "remote", "url": "https://jira.example.com/mcp", "enabled": false } }}Sie können bestimmte Server in Ihrer lokalen Konfiguration aktivieren:
{ "mcp": { "jira": { "type": "remote", "url": "https://jira.example.com/mcp", "enabled": true } }}Global
Platzieren Sie Ihre globale OpenCode-Konfiguration in ~/.config/opencode/opencode.json. Verwenden Sie die globale Konfiguration für benutzerweite Einstellungen wie Themen, Anbieter oder Tastenkombinationen.
Die globale Konfiguration überschreibt die Standardeinstellungen der Remote-Organisation.
Pro Projekt
Fügen Sie opencode.json in Ihrem Projektstamm hinzu. Die Projektkonfiguration hat unter den Standardkonfigurationsdateien die höchste Priorität – sie überschreibt sowohl globale als auch Remote-Konfigurationen.
Wenn OpenCode gestartet wird, sucht es im aktuellen Verzeichnis nach einer Konfigurationsdatei oder durchsucht das nächstgelegene Git-Verzeichnis.
Dies kann auch sicher in Git eingecheckt werden und dasselbe Schema wie das globale verwenden.
Benutzerdefinierter Pfad
Geben Sie mithilfe der Umgebungsvariablen OPENCODE_CONFIG einen benutzerdefinierten Konfigurationsdateipfad an.
export OPENCODE_CONFIG=/path/to/my/custom-config.jsonopencode run "Hello world"Die benutzerdefinierte Konfiguration wird in der Rangfolge zwischen globalen und Projektkonfigurationen geladen.
Benutzerdefiniertes Verzeichnis
Geben Sie mit OPENCODE_CONFIG_DIR ein benutzerdefiniertes Konfigurationsverzeichnis an.
Umgebungsvariable. Dieses Verzeichnis wird nach Agenten, Befehlen,
Modi und Plugins genau wie das Standardverzeichnis .opencode und sollten
folgen der gleichen Struktur.
export OPENCODE_CONFIG_DIR=/path/to/my/config-directoryopencode run "Hello world"Das benutzerdefinierte Verzeichnis wird nach den Verzeichnissen global config und .opencode geladen, sodass es deren Einstellungen überschreiben kann.
Schema
Die Konfigurationsdatei verfügt über ein Schema, das in opencode.ai/config.json definiert ist.
Ihr Editor sollte in der Lage sein, basierend auf dem Schema zu validieren und automatisch zu vervollständigen.
TUI
Sie können TUI-spezifische Einstellungen über die Option tui konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "tui": { "scroll_speed": 3, "scroll_acceleration": { "enabled": true }, "diff_style": "auto" }}Verfügbare Optionen:
scroll_acceleration.enabled– Scrollbeschleunigung im macOS-Stil aktivieren. Hat Vorrang vorscroll_speed.scroll_speed– Benutzerdefinierter Scrollgeschwindigkeitsmultiplikator (Standard:3, Minimum:1). Wird ignoriert, wennscroll_acceleration.enabledgleichtrueist.diff_style– Steuern Sie das Diff-Rendering."auto"passt sich der Terminalbreite an,"stacked"zeigt immer eine einzelne Spalte an.
Learn more about using the TUI here.
Server
Sie können Servereinstellungen für die Befehle opencode serve und opencode web über die Option server konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "server": { "port": 4096, "hostname": "0.0.0.0", "mdns": true, "mdnsDomain": "myproject.local", "cors": ["http://localhost:5173"] }}Verfügbare Optionen:
port– Port zum Abhören.hostname– Hostname zum Abhören. Wennmdnsaktiviert ist und kein Hostname festgelegt ist, wird standardmäßig0.0.0.0verwendet.mdns– mDNS-Diensterkennung aktivieren. Dadurch können andere Geräte im Netzwerk Ihres OpenCode-Servers erkannt werden.mdnsDomain– Benutzerdefinierter Domänenname für den mDNS-Dienst. Standardmäßig istopencode.local. Nützlich für die Ausführung mehrerer Instanzen im selben Netzwerk.cors– Zusätzliche Ursprünge, um CORS zu ermöglichen, wenn der HTTP-Server von einem browserbasierten Client aus verwendet wird. Die Werte müssen vollständige Ursprünge haben (Schema + Host + optionaler Port), z. B.https://app.example.com.
Learn more about the server here.
Tools
Sie können die Tools, die ein LLM verwenden kann, über die Option tools verwalten.
{ "$schema": "https://opencode.ai/config.json", "tools": { "write": false, "bash": false }}Models
Sie können die Anbieter und Modelle, die Sie in Ihrer OpenCode-Konfiguration verwenden möchten, über die Optionen provider, model und small_model konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "provider": {}, "model": "anthropic/claude-sonnet-4-5", "small_model": "anthropic/claude-haiku-4-5"}Die Option small_model konfiguriert ein separates Modell für einfache Aufgaben wie die Titelgenerierung. Standardmäßig versucht OpenCode, ein günstigeres Modell zu verwenden, sofern eines bei Ihrem Anbieter verfügbar ist, andernfalls greift es auf Ihr Hauptmodell zurück.
Zu den Anbieteroptionen können timeout und setCacheKey gehören:
{ "$schema": "https://opencode.ai/config.json", "provider": { "anthropic": { "options": { "timeout": 600000, "setCacheKey": true } } }}timeout– Anforderungszeitlimit in Millisekunden (Standard: 300000). Zum Deaktivieren auffalsesetzen.setCacheKey– Stellen Sie sicher, dass immer ein Cache-Schlüssel für den angegebenen Anbieter festgelegt ist.
Sie können auch local models konfigurieren. Learn more.
Anbieterspezifische Optionen
Einige Anbieter unterstützen zusätzliche Konfigurationsoptionen über die allgemeinen Einstellungen timeout und apiKey hinaus.
Amazon Bedrock
Amazon Bedrock unterstützt AWS-spezifische Konfigurationen:
{ "$schema": "https://opencode.ai/config.json", "provider": { "amazon-bedrock": { "options": { "region": "us-east-1", "profile": "my-aws-profile", "endpoint": "https://bedrock-runtime.us-east-1.vpce-xxxxx.amazonaws.com" } } }}region– AWS-Region für Bedrock (standardmäßigAWS_REGIONenv var oderus-east-1)profile– AWS benanntes Profil von~/.aws/credentials(standardmäßigAWS_PROFILEUmgebungsvariable)endpoint– Benutzerdefinierter Endpunkt URL für VPC-Endpunkte. Dies ist ein Alias für die generische OptionbaseURLunter Verwendung der AWS-spezifischen Terminologie. Wenn beide angegeben sind, hatendpointVorrang.
Learn more about Amazon Bedrock configuration.
Themes
Sie können das Thema, das Sie in Ihrer OpenCode-Konfiguration verwenden möchten, über die Option theme konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "theme": ""}Agents
Über die Option agent können Sie spezielle Agenten für bestimmte Aufgaben konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "agent": { "code-reviewer": { "description": "Reviews code for best practices and potential issues", "model": "anthropic/claude-sonnet-4-5", "prompt": "You are a code reviewer. Focus on security, performance, and maintainability.", "tools": { // Disable file modification tools for review-only agent "write": false, "edit": false, }, }, },}Sie können Agenten auch mithilfe von Markdown-Dateien in ~/.config/opencode/agents/ oder .opencode/agents/ definieren. Learn more here.
Standardagent
Sie können den Standardagenten mit der Option default_agent festlegen. Dadurch wird bestimmt, welcher Agent verwendet wird, wenn keiner explizit angegeben wird.
{ "$schema": "https://opencode.ai/config.json", "default_agent": "plan"}Der Standardagent muss ein Primäragent (kein Subagent) sein. Dies kann ein integrierter Agent wie "build" oder "plan" oder ein von Ihnen definierter custom agent sein. Wenn der angegebene Agent nicht existiert oder ein Subagent ist, greift OpenCode mit einer Warnung auf "build" zurück.
Diese Einstellung gilt für alle Schnittstellen: TUI, CLI (opencode run), Desktop-App und GitHub Aktion.
Sharing
Sie können die Funktion share über die Option share konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "share": "manual"}Dazu braucht es:
"manual"– Manuelles Teilen über Befehle zulassen (Standard)"auto"– Neue Konversationen automatisch teilen"disabled"– Teile vollständig deaktivieren
Standardmäßig ist die Freigabe auf den manuellen Modus eingestellt, in dem Sie Konversationen explizit mit dem Befehl /share teilen müssen.
Befehle
Sie können benutzerdefinierte Befehle für sich wiederholende Aufgaben über die Option command konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "command": { "test": { "template": "Run the full test suite with coverage report and show any failures.\nFocus on the failing tests and suggest fixes.", "description": "Run tests with coverage", "agent": "build", "model": "anthropic/claude-haiku-4-5", }, "component": { "template": "Create a new React component named $ARGUMENTS with TypeScript support.\nInclude proper typing and basic structure.", "description": "Create a new component", }, },}Sie können Befehle auch mithilfe von Markdown-Dateien in ~/.config/opencode/commands/ oder .opencode/commands/ definieren. Learn more here.
Keybinds
Sie können Ihre Tastenkombinationen über die Option keybinds anpassen.
{ "$schema": "https://opencode.ai/config.json", "keybinds": {}}Autoupdate
OpenCode lädt beim Start automatisch alle neuen Updates herunter. Sie können dies mit der Option autoupdate deaktivieren.
{ "$schema": "https://opencode.ai/config.json", "autoupdate": false}Wenn Sie keine Updates wünschen, aber dringend möchten, wenn eine neue Version verfügbar ist, setzen Sie autoupdate auf "notify".
Beachten Sie, dass dies nur funktioniert, wenn es nicht mit einem Paketmanager wie Homebrew installiert wurde.
Formatters
Sie können Codeformatierer über die Option formatter konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "formatter": { "prettier": { "disabled": true }, "custom-prettier": { "command": ["npx", "prettier", "--write", "$FILE"], "environment": { "NODE_ENV": "development" }, "extensions": [".js", ".ts", ".jsx", ".tsx"] } }}Learn more about formatters here.
Permissions
OpenCode erlaubt standardmäßig alle Vorgänge, ohne dass eine ausdrückliche Genehmigung erforderlich ist. Sie können dies mit der Option permission ändern.
Um beispielsweise sicherzustellen, dass die Tools edit und bash eine Benutzergenehmigung erfordern:
{ "$schema": "https://opencode.ai/config.json", "permission": { "edit": "ask", "bash": "ask" }}Learn more about permissions here.
Compaction
Sie können das Verhalten der Kontextkomprimierung über die Option compaction steuern.
{ "$schema": "https://opencode.ai/config.json", "compaction": { "auto": true, "prune": true }}auto– Die Sitzung wird automatisch komprimieren, wenn der Kontext voll ist (Standard:true).prune– Alte Tool-Ausgaben entfernen, um Token zu sparen (Standard:true).
Watcher
Sie können Datei-Watcher-Ignoriermuster über die Option watcher konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "watcher": { "ignore": ["node_modules/**", "dist/**", ".git/**"] }}Muster folgen der Glob-Syntax. Verwenden Sie diese Option, um verrauschte Verzeichnisse von der Dateiüberwachung auszuschließen.
MCP Server
Sie können den MCP-Server, den Sie verwenden möchten, über die Option mcp konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "mcp": {}}Plugins
Plugins erweitert OpenCode mit benutzerdefinierten Tools, Hooks und Integrationen.
Platzieren Sie Ihre Plugin-Dateien in .opencode/plugins/ oder ~/.config/opencode/plugins/. Sie können Plugins auch über die Option plugin von npm laden.
{ "$schema": "https://opencode.ai/config.json", "plugin": ["opencode-helicone-session", "@my-org/custom-plugin"]}Instructions
Sie können die Anweisungen für das von Ihnen verwendete Modell über die Option instructions konfigurieren.
{ "$schema": "https://opencode.ai/config.json", "instructions": ["CONTRIBUTING.md", "docs/guidelines.md", ".cursor/rules/*.md"]}Dies erfordert eine Reihe von Pfaden und Glob-Mustern zu Anweisungsdateien. Erfahren Sie mehr über Regeln hier.
Deaktivierte Anbieter
Sie können Anbieter, die automatisch geladen werden, über die Option disabled_providers deaktivieren. Dies ist nützlich, wenn Sie verhindern möchten, dass bestimmte Anbieter geladen werden, selbst wenn deren Anmeldeinformationen verfügbar sind.
{ "$schema": "https://opencode.ai/config.json", "disabled_providers": ["openai", "gemini"]}Die Option disabled_providers akzeptiert ein Array des Anbieters IDs. Wenn ein Anbieter deaktiviert ist:
- Es wird nicht geladen, selbst wenn Umgebungsvariablen festgelegt sind.
- Es wird nicht geladen, selbst wenn API-Schlüssel über den Befehl
/connectkonfiguriert werden. - Die Modelle des Anbieters erscheinen nicht in der Modellauswahlliste.
Aktivierte Anbieter
Sie können über die Option enabled_providers eine Zulassungsliste für Anbieter angeben. Wenn diese Option festgelegt ist, werden nur die angegebenen Anbieter aktiviert und alle anderen werden ignoriert.
{ "$schema": "https://opencode.ai/config.json", "enabled_providers": ["anthropic", "openai"]}Dies ist nützlich, wenn Sie OpenCode darauf beschränken möchten, nur bestimmte Anbieter zu verwenden, anstatt sie einzeln zu deaktivieren.
Wenn ein Anbieter sowohl in enabled_providers als auch in disabled_providers vorkommt, hat disabled_providers aus Gründen der Abwärtskompatibilität Vorrang.
Experimental
Der Schlüssel experimental enthält Optionen, die sich in der aktiven Entwicklung befinden.
{ "$schema": "https://opencode.ai/config.json", "experimental": {}}Variablen
Sie können die Variablenersetzung in Ihren Konfigurationsdateien verwenden, um auf Umgebungsvariablen und Dateiinhalte zu verweisen.
Umgebungsvariablen
Verwenden Sie {env:VARIABLE_NAME}, um Umgebungsvariablen zu ersetzen:
{ "$schema": "https://opencode.ai/config.json", "model": "{env:OPENCODE_MODEL}", "provider": { "anthropic": { "models": {}, "options": { "apiKey": "{env:ANTHROPIC_API_KEY}" } } }}Wenn die Umgebungsvariable nicht gesetzt ist, wird sie durch eine leere Zeichenfolge ersetzt.
Dateien
Verwenden Sie {file:path/to/file}, um den Inhalt einer Datei zu ersetzen:
{ "$schema": "https://opencode.ai/config.json", "instructions": ["./custom-instructions.md"], "provider": { "openai": { "options": { "apiKey": "{file:~/.secrets/openai-key}" } } }}Dateipfade können sein:
- Relativ zum Konfigurationsdateiverzeichnis
- Oder absolute Pfade beginnend mit
/oder~
Diese sind nützlich für:
- Bewahren Sie vertrauliche Daten wie API-Schlüssel in separaten Dateien auf.
- Einschließlich große Anweisungsdateien, ohne Ihre Konfiguration zu überladen.
- Gemeinsame Nutzung gemeinsamer Konfigurationsausschnitte über mehrere Konfigurationsdateien hinweg.