跳转到内容

CLI

opencode CLI 选项和命令。

默认情况下,opencode CLI 在不带任何参数运行时启动 TUI

Terminal window
opencode

但它也接受本页记录的命令。这允许您以编程方式与 opencode 交互。

Terminal window
opencode run "Explain how closures work in JavaScript"

tui

启动 opencode 终端用户界面。

Terminal window
opencode [project]

Flags

FlagShortDescription
--continue-c继续上一个会话
--session-s继续的会话 ID
--fork继续时分叉会话(与 --continue--session 一起使用)
--prompt使用的提示
--model-m使用的模型 (provider/model)
--agent使用的代理
--port监听端口
--hostname监听的主机名

Commands

opencode CLI 还具有以下命令。


agent

管理 opencode 代理。

Terminal window
opencode agent [command]

attach

将终端附加到通过 serveweb 命令启动的已运行 opencode 后端服务器。

Terminal window
opencode attach [url]

这允许将 TUI 与远程 opencode 后端一起使用。例如:

Terminal window
# Start the backend server for web/mobile access
opencode web --port 4096 --hostname 0.0.0.0
# In another terminal, attach the TUI to the running backend
opencode attach http://10.20.30.40:4096

Flags

FlagShortDescription
--dir启动 TUI 的工作目录
--session-s继续的会话 ID

create

使用自定义配置创建新代理。

Terminal window
opencode agent create

此命令将指导您使用自定义系统提示和工具配置创建新代理。


list

列出所有可用的代理。

Terminal window
opencode agent list

auth

用于管理提供商的凭据和登录的命令。

Terminal window
opencode auth [command]

login

opencode 由 Models.dev 上的提供商列表支持,因此您可以使用 opencode auth login 来为您想要使用的任何提供商配置 API 密钥。它存储在 ~/.local/share/opencode/auth.json 中。

Terminal window
opencode auth login

当 opencode 启动时,它会从凭据文件加载提供商。以及如果在您的环境或项目中的 .env 文件中定义了任何密钥。


list

列出凭据文件中存储的所有经过身份验证的提供商。

Terminal window
opencode auth list

或者简短的版本。

Terminal window
opencode auth ls

logout

通过从凭据文件中清除提供商,将您从提供商中注销。

Terminal window
opencode auth logout

github

管理 GitHub 代理以实现存储库自动化。

Terminal window
opencode github [command]

install

在您的存储库中安装 GitHub 代理。

Terminal window
opencode github install

这将设置必要的 GitHub Actions 工作流程并指导您完成配置过程。 了解更多


run

运行 GitHub 代理。这通常用在 GitHub Actions 中。

Terminal window
opencode github run
Flags
FlagDescription
--event用于运行代理的 GitHub 模拟事件
--tokenGitHub 个人访问 Token

mcp

管理模型上下文协议 (MCP) 服务器。

Terminal window
opencode mcp [command]

add

将 MCP 服务器添加到您的配置中。

Terminal window
opencode mcp add

此命令将指导您添加本地或远程 MCP 服务器。


list

列出所有已配置的 MCP 服务器及其连接状态。

Terminal window
opencode mcp list

或者使用简短版本。

Terminal window
opencode mcp ls

auth

使用启用 OAuth 的 MCP 服务器进行身份验证。

Terminal window
opencode mcp auth [name]

如果您不提供服务器名称,系统将提示您从可用的支持 OAuth 的服务器中进行选择。

您还可以列出支持 OAuth 的服务器及其身份验证状态。

Terminal window
opencode mcp auth list

或者使用简短版本。

Terminal window
opencode mcp auth ls

logout

删除 MCP 服务器的 OAuth 凭据。

Terminal window
opencode mcp logout [name]

debug

调试 MCP 服务器的 OAuth 连接问题。

Terminal window
opencode mcp debug <name>

models

列出已配置提供商的所有可用模型。

Terminal window
opencode models [provider]

此命令以 provider/model 格式显示您配置的提供商中可用的所有模型。

这对于确定 你的配置 中使用的确切模型名称很有帮助。

您可以选择提供提供商 ID 并按该提供商筛选模型。

Terminal window
opencode models anthropic

Flags

FlagDescription
--refresh从 models.dev 刷新模型缓存
--verbose使用更详细的模型输出(包括成本等元数据)

使用 --refresh 标志来更新服务器的模型列表。当新模型已添加到提供商并且您希望在 opencode 中查看它们时,这非常有用。

Terminal window
opencode models --refresh

run

通过直接传递提示以非交互模式运行 opencode。

Terminal window
opencode run [message..]

这对于编写脚本、自动化,或者当您想要快速获得答案而不是完整的 TUI 时非常有用。例如。

Terminal window
opencode run Explain the use of context in Go

您还可以附加到正在运行的 opencode serve 实例,以避免每次运行时 MCP 服务器冷启动时间:

Terminal window
# Start a headless server in one terminal
opencode serve
# In another terminal, run commands that attach to it
opencode run --attach http://localhost:4096 "Explain async/await in JavaScript"

Flags

FlagShortDescription
--command要运行的命令,使用消息作为参数
--continue-c继续上一个会话
--session-s继续的会话 ID
--fork继续时分叉会话(与 --continue--session 一起使用)
--share分享会话
--model-m使用的模型 (provider/model)
--agent使用的代理
--file-f要附加到消息的文件
--format格式:default(格式化)或 json(原始 JSON 事件)
--title会话标题(如果未提供值,则使用截断的提示)
--attach连接到正在运行的 opencode 服务器(例如,http://localhost:4096)
--port本地服务器的端口(默认为随机端口)

serve

启动无头 opencode 服务器以进行 API 访问。查看 服务器文档 以获取完整的 HTTP 接口。

Terminal window
opencode serve

这将启动一个 HTTP 服务器,该服务器提供对 opencode 功能的 API 访问,无需 TUI 界面。设置 OPENCODE_SERVER_PASSWORD 以启用 HTTP 基本身份验证(用户名默认为 opencode)。

Flags

FlagDescription
--port监听端口
--hostname监听的主机名
--mdns启用 mDNS 发现
--cors允许 CORS 的其他浏览器源

session

管理 opencode 会话。

Terminal window
opencode session [command]

list

列出所有 opencode 会话。

Terminal window
opencode session list
Flags
FlagShortDescription
--max-count-n限制为最近的 N 个会话
--format输出格式:table 或 json(table)

stats

显示 opencode 会话的 Token 使用情况和成本统计信息。

Terminal window
opencode stats

Flags

FlagDescription
--days显示过去 N 天(所有时间)的统计数据
--tools显示工具数量(全部)
--models显示模型使用情况细分(默认隐藏)。输入一个数字来显示前 N
--project按项目过滤(所有项目,空字符串:当前项目)

export

将会话数据导出为 JSON。

Terminal window
opencode export [sessionID]

如果您不提供会话 ID,系统将提示您从可用的会话中进行选择。


import

从 JSON 文件或 opencode 共享 URL 导入会话数据。

Terminal window
opencode import <file>

您可以从本地文件或 opencode 共享 URL 导入。

Terminal window
opencode import session.json
opencode import https://opncd.ai/s/abc123

web

使用 Web 界面启动无头 opencode 服务器。

Terminal window
opencode web

这将启动 HTTP 服务器并打开 Web 浏览器以通过 Web 界面访问 opencode。设置 OPENCODE_SERVER_PASSWORD 以启用 HTTP 基本身份验证(用户名默认为 opencode)。

Flags

FlagDescription
--port监听端口
--hostname监听的主机名
--mdns启用 mDNS 发现
--cors允许 CORS 的其他浏览器源

acp

启动 ACP (Agent Client Protocol) 服务器。

Terminal window
opencode acp

此命令启动一个 ACP 服务器,该服务器使用 nd-JSON 通过 stdin/stdout 进行通信。

Flags

FlagDescription
--cwd工作目录
--port监听端口
--hostname监听的主机名

uninstall

卸载 opencode 并删除所有相关文件。

Terminal window
opencode uninstall

Flags

FlagShortDescription
--keep-config-c保留配置文件
--keep-data-d保留会话数据和快照
--dry-run显示将删除的内容但不实际删除
--force-f跳过确认提示

upgrade

将 opencode 更新到最新版本或特定版本。

Terminal window
opencode upgrade [target]

升级到最新版本。

Terminal window
opencode upgrade

升级到特定版本。

Terminal window
opencode upgrade v0.1.48

Flags

FlagShortDescription
--method-m使用的安装方法;curl, npm, pnpm, bun, brew

Global Flags

opencode CLI 接受以下全局标志。

FlagShortDescription
--help-h显示帮助
--version-v打印版本号
--print-logs将日志打印到 stderr
--log-level日志级别 (DEBUG, INFO, WARN, ERROR)

Environment variables

可以使用环境变量配置 opencode。

VariableTypeDescription
OPENCODE_AUTO_SHAREboolean自动共享会话
OPENCODE_GIT_BASH_PATHstringWindows 上 Git Bash 可执行文件的路径
OPENCODE_CONFIGstring配置文件路径
OPENCODE_CONFIG_DIRstring配置目录的路径
OPENCODE_CONFIG_CONTENTstring内联 json 配置内容
OPENCODE_DISABLE_AUTOUPDATEboolean禁用自动更新检查
OPENCODE_DISABLE_PRUNEboolean禁用数据的修剪
OPENCODE_DISABLE_TERMINAL_TITLEboolean禁用自动终端标题更新
OPENCODE_PERMISSIONstring内联 json 权限配置
OPENCODE_DISABLE_DEFAULT_PLUGINSboolean禁用默认插件
OPENCODE_DISABLE_LSP_DOWNLOADboolean禁用自动 LSP 服务器下载
OPENCODE_ENABLE_EXPERIMENTAL_MODELSboolean启用实验模型
OPENCODE_DISABLE_AUTOCOMPACTboolean禁用自动上下文压缩
OPENCODE_DISABLE_CLAUDE_CODEboolean禁用从 .claude 读取(提示+技能)
OPENCODE_DISABLE_CLAUDE_CODE_PROMPTboolean禁用读取 ~/.claude/CLAUDE.md
OPENCODE_DISABLE_CLAUDE_CODE_SKILLSboolean禁用加载 .claude/skills
OPENCODE_DISABLE_MODELS_FETCHboolean禁用从远程源获取模型
OPENCODE_FAKE_VCSstring用于测试目的的伪造 VCS
OPENCODE_DISABLE_FILETIME_CHECKboolean禁用文件时间检查以进行优化
OPENCODE_CLIENTstring客户端标识符(默认为 cli
OPENCODE_ENABLE_EXAboolean启用 Exa 网络搜索工具
OPENCODE_SERVER_PASSWORDstringserve/web 启用基本身份验证
OPENCODE_SERVER_USERNAMEstring覆盖基本身份验证用户名(默认 opencode
OPENCODE_MODELS_URLstring用于获取模型配置的自定义 URL

Experimental

这些环境变量启用可能会更改或删除的实验性功能。

VariableTypeDescription
OPENCODE_EXPERIMENTALboolean启用所有实验性功能
OPENCODE_EXPERIMENTAL_ICON_DISCOVERYboolean启用图标发现
OPENCODE_EXPERIMENTAL_DISABLE_COPY_ON_SELECTboolean在 TUI 中禁用选择时复制
OPENCODE_EXPERIMENTAL_BASH_DEFAULT_TIMEOUT_MSnumberbash 命令的默认超时(以毫秒为单位)
OPENCODE_EXPERIMENTAL_OUTPUT_TOKEN_MAXnumberLLM 响应的最大输出 Token
OPENCODE_EXPERIMENTAL_FILEWATCHERboolean为整个目录启用文件观察器
OPENCODE_EXPERIMENTAL_OXFMTboolean启用 oxfmt 格式化程序
OPENCODE_EXPERIMENTAL_LSP_TOOLboolean启用实验性 LSP 工具
OPENCODE_EXPERIMENTAL_DISABLE_FILEWATCHERboolean禁用文件观察器
OPENCODE_EXPERIMENTAL_EXAboolean启用实验性 Exa 功能
OPENCODE_EXPERIMENTAL_LSP_TYboolean启用实验性 LSP 类型检查
OPENCODE_EXPERIMENTAL_MARKDOWNboolean启用实验性 Markdown 功能
OPENCODE_EXPERIMENTAL_PLAN_MODEboolean启用计划模式