故障排除
常见问题及其解决方法。
要调试 OpenCode 的问题,请先检查其存储在磁盘上的日志和本地数据。
日志
日志文件写入位置:
- macOS/Linux:
~/.local/share/opencode/log/ - Windows: 按
WIN+R并粘贴%USERPROFILE%\.local\share\opencode\log
日志文件以时间戳命名(例如 2025-01-09T123456.log),并保留最近的 10 个日志文件。
你可以通过 --log-level 命令行选项设置日志级别以获取更详细的调试信息。例如:opencode --log-level DEBUG。
存储
OpenCode 将会话数据和其他应用数据存储在磁盘上:
- macOS/Linux:
~/.local/share/opencode/ - Windows: 按
WIN+R并粘贴%USERPROFILE%\.local\share\opencode
该目录包含:
auth.json- 身份验证数据,如 API 密钥、OAuth Tokenlog/- 应用日志project/- 项目特定数据,如会话和消息数据- 如果项目位于 Git 仓库中,则存储在
./<project-slug>/storage/ - 如果不是 Git 仓库,则存储在
./global/storage/
- 如果项目位于 Git 仓库中,则存储在
桌面应用
OpenCode Desktop 会在后台运行一个本地 OpenCode 服务器(即 opencode-cli 附属进程)。大多数问题是由插件异常、缓存损坏或错误的服务器设置引起的。
快速检查
- 完全退出并重新启动应用。
- 如果应用显示错误页面,请点击重新启动并复制错误详情。
- 仅限 macOS:
OpenCode菜单 -> Reload Webview(当 UI 空白或冻结时有效)。
禁用插件
如果桌面应用在启动时崩溃、卡住或行为异常,请先禁用插件。
检查全局配置
打开你的全局配置文件,查找 plugin 键。
- macOS/Linux:
~/.config/opencode/opencode.jsonc(或~/.config/opencode/opencode.json) - macOS/Linux(旧版安装):
~/.local/share/opencode/opencode.jsonc - Windows: 按
WIN+R并粘贴%USERPROFILE%\.config\opencode\opencode.jsonc
如果你配置了插件,请通过移除该键或将其设置为空数组来临时禁用它们:
{ "$schema": "https://opencode.ai/config.json", "plugin": [],}检查插件目录
OpenCode 还可以从磁盘加载本地插件。临时将这些插件移走(或重命名文件夹),然后重新启动桌面应用:
- 全局插件
- macOS/Linux:
~/.config/opencode/plugins/ - Windows: 按
WIN+R并粘贴%USERPROFILE%\.config\opencode\plugins
- macOS/Linux:
- 项目插件(仅当你使用了项目级配置时)
<your-project>/.opencode/plugins/
如果应用恢复正常,请逐个重新启用插件,找出导致问题的那个。
清除缓存
如果禁用插件没有帮助(或插件安装卡住了),请清除缓存以便 OpenCode 重新构建。
- 完全退出 OpenCode Desktop。
- 删除缓存目录:
- macOS: Finder ->
Cmd+Shift+G-> 粘贴~/.cache/opencode - Linux: 删除
~/.cache/opencode(或运行rm -rf ~/.cache/opencode) - Windows: 按
WIN+R并粘贴%USERPROFILE%\.cache\opencode
- 重新启动 OpenCode Desktop。
修复服务器连接问题
OpenCode Desktop 可以启动自己的本地服务器(默认行为),也可以连接到你配置的服务器 URL。
如果你看到**“Connection Failed”**对话框(或应用始终停留在启动画面),请检查自定义服务器 URL。
清除桌面默认服务器 URL
在主页面上,点击服务器名称(带有状态指示点)以打开服务器选择器。在默认服务器部分,点击清除。
从配置中移除 server.port / server.hostname
如果你的 opencode.json(c) 包含 server 部分,请临时移除该部分并重新启动桌面应用。
检查环境变量
如果你在环境中设置了 OPENCODE_PORT,桌面应用将尝试使用该端口作为本地服务器端口。
- 取消设置
OPENCODE_PORT(或选择一个空闲端口)并重新启动。
Linux: Wayland / X11 问题
在 Linux 上,某些 Wayland 设置可能会导致窗口空白或合成器错误。
- 如果你使用 Wayland 且应用出现空白或崩溃,请尝试使用
OC_ALLOW_WAYLAND=1启动。 - 如果情况变得更糟,请移除该设置并尝试在 X11 会话下启动。
Windows: WebView2 运行时
在 Windows 上,OpenCode Desktop 需要 Microsoft Edge WebView2 Runtime。如果应用打开后是空白窗口或无法启动,请安装或更新 WebView2 后重试。
Windows: 常见性能问题
如果你在 Windows 上遇到性能缓慢、文件访问问题或终端问题,请尝试使用 WSL (Windows Subsystem for Linux)。WSL 提供了一个 Linux 环境,能更好地与 OpenCode 的功能兼容。
通知不显示
OpenCode Desktop 仅在以下情况下显示系统通知:
- 在操作系统设置中已为 OpenCode 启用通知,且
- 应用窗口未处于焦点状态。
重置桌面应用存储(最后手段)
如果应用无法启动且你无法从 UI 内部清除设置,请重置桌面应用的保存状态。
- 退出 OpenCode Desktop。
- 找到并删除以下文件(它们位于 OpenCode Desktop 应用数据目录中):
opencode.settings.dat(桌面默认服务器 URL)opencode.global.dat和opencode.workspace.*.dat(UI 状态,如最近的服务器/项目)
快速找到该目录:
- macOS: Finder ->
Cmd+Shift+G->~/Library/Application Support(然后搜索上述文件名) - Linux: 在
~/.local/share下搜索上述文件名 - Windows: 按
WIN+R->%APPDATA%(然后搜索上述文件名)
获取帮助
如果你遇到 OpenCode 的问题:
-
在 GitHub 上报告问题
报告 Bug 或请求功能的最佳方式是通过我们的 GitHub 仓库:
github.com/anomalyco/opencode/issues
在创建新 Issue 之前,请先搜索已有的 Issue,看看你的问题是否已被报告。
-
加入我们的 Discord
如需实时帮助和社区讨论,请加入我们的 Discord 服务器:
常见问题
以下是一些常见问题及其解决方法。
OpenCode 无法启动
- 检查日志中的错误消息
- 尝试使用
--print-logs运行以在终端中查看输出 - 使用
opencode upgrade确保你使用的是最新版本
身份验证问题
- 尝试在 TUI 中使用
/connect命令重新进行身份验证 - 检查你的 API 密钥是否有效
- 确保你的网络允许连接到提供商的 API
模型不可用
- 检查你是否已通过提供商的身份验证
- 验证配置中的模型名称是否正确
- 某些模型可能需要特定的访问权限或订阅
如果你遇到 ProviderModelNotFoundError,很可能是在某处错误地引用了模型。
模型应按如下方式引用:<providerId>/<modelId>
示例:
openai/gpt-4.1openrouter/google/gemini-2.5-flashopencode/kimi-k2
要查看你有权访问哪些模型,请运行 opencode models
ProviderInitError
如果你遇到 ProviderInitError,很可能是配置无效或已损坏。
要解决此问题:
-
首先,按照提供商指南验证你的提供商是否已正确设置
-
如果问题仍然存在,请尝试清除已存储的配置:
Terminal window rm -rf ~/.local/share/opencode在 Windows 上,按
WIN+R并删除:%USERPROFILE%\.local\share\opencode -
在 TUI 中使用
/connect命令重新与提供商进行身份验证。
AI_APICallError 和提供商包问题
如果你遇到 API 调用错误,可能是由于提供商包过期导致的。OpenCode 会根据需要动态安装提供商包(OpenAI、Anthropic、Google 等)并将它们缓存到本地。
要解决提供商包问题:
-
清除提供商包缓存:
Terminal window rm -rf ~/.cache/opencode在 Windows 上,按
WIN+R并删除:%USERPROFILE%\.cache\opencode -
重新启动 OpenCode 以重新安装最新的提供商包
这将强制 OpenCode 下载最新版本的提供商包,通常可以解决模型参数和 API 变更带来的兼容性问题。
在 Linux 上复制/粘贴不可用
Linux 用户需要安装以下剪贴板工具之一,复制/粘贴功能才能正常工作:
对于 X11 系统:
apt install -y xclip# orapt install -y xsel对于 Wayland 系统:
apt install -y wl-clipboard对于无头环境:
apt install -y xvfb# and run:Xvfb :99 -screen 0 1024x768x24 > /dev/null 2>&1 &export DISPLAY=:99.0OpenCode 会检测你是否正在使用 Wayland 并优先使用 wl-clipboard,否则将按以下顺序尝试查找剪贴板工具:xclip 和 xsel。