中文
文档
故障排除

故障排除

常见问题及其解决方法。

要调试 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 令牌
  • log/ - 应用日志
  • project/ - 项目特定数据,如会话和消息数据
    • 如果项目在 Git 仓库中,存储在 ./<project-slug>/storage/
    • 如果不是 Git 仓库,存储在 ./global/storage/

桌面应用

OpenCode Desktop 在后台运行本地 OpenCode 服务器(opencode-cli 辅助程序)。大多数问题是由行为异常的插件、损坏的缓存或错误的服务器设置引起的。

快速检查

  • 完全退出并重新启动应用。
  • 如果应用显示错误屏幕,点击 重启 并复制错误详情。
  • 仅限 macOS:OpenCode 菜单 -> 重新加载 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
  • 项目插件(仅当你使用项目级配置时)
    • <your-project>/.opencode/plugins/

如果应用恢复正常,逐个重新启用插件以找出导致问题的插件。


清除缓存

如果禁用插件没有帮助(或插件安装卡住),清除缓存以便 OpenCode 可以重建它。

  1. 完全退出 OpenCode Desktop。
  2. 删除缓存目录:
  • macOS: Finder -> Cmd+Shift+G -> 粘贴 ~/.cache/opencode
  • Linux: 删除 ~/.cache/opencode(或运行 rm -rf ~/.cache/opencode
  • Windows: 按 WIN+R 并粘贴 %USERPROFILE%\.cache\opencode
  1. 重启 OpenCode Desktop。

修复服务器连接问题

OpenCode Desktop 可以启动自己的本地服务器(默认)或连接到你配置的服务器 URL。

如果你看到 连接失败 对话框(或应用一直停留在启动画面),检查是否有自定义服务器 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 提供了一个与 OpenCode 功能更无缝配合的 Linux 环境。


通知不显示

OpenCode Desktop 仅在以下情况下显示系统通知:

  • 在你的操作系统设置中为 OpenCode 启用了通知,且
  • 应用窗口未处于焦点状态。

重置桌面应用存储(最后手段)

如果应用无法启动且你无法从 UI 内部清除设置,重置桌面应用的保存状态。

  1. 退出 OpenCode Desktop。
  2. 找到并删除这些文件(它们位于 OpenCode Desktop 应用数据目录中):
  • opencode.settings.dat(桌面默认服务器 URL)
  • opencode.global.datopencode.workspace.*.dat(UI 状态,如最近的服务器/项目)

快速找到目录:

  • macOS: Finder -> Cmd+Shift+G -> ~/Library/Application Support(然后搜索上述文件名)
  • Linux: 在 ~/.local/share 下搜索上述文件名
  • Windows: 按 WIN+R -> %APPDATA%(然后搜索上述文件名)

获取帮助

如果你在使用 OpenCode 时遇到问题:

  1. 在 GitHub 上报告问题

    报告 bug 或请求功能的最佳方式是通过我们的 GitHub 仓库:

    github.com/anomalyco/opencode/issues (opens in a new tab)

    在创建新问题之前,搜索现有问题以查看你的问题是否已被报告。

  2. 加入我们的 Discord

    获取实时帮助和社区讨论,加入我们的 Discord 服务器:

    opencode.ai/discord (opens in a new tab)


常见问题

以下是一些常见问题及其解决方法。


OpenCode 无法启动

  • 检查日志中的错误信息
  • 尝试使用 --print-logs 运行以在终端中查看输出
  • 使用 opencode upgrade 确保你拥有最新版本

认证问题

  • 尝试在 TUI 中使用 /connect 命令重新认证
  • 检查你的 API 密钥是否有效
  • 确保你的网络允许连接到提供商的 API

模型不可用

  • 检查你是否已通过提供商认证
  • 验证配置中的模型名称是否正确
  • 某些模型可能需要特定的访问权限或订阅

如果你遇到 ProviderModelNotFoundError,你很可能在某处错误地引用了模型。模型应该这样引用:<providerId>/<modelId>

示例:

  • openai/gpt-4.1
  • openrouter/google/gemini-2.5-flash
  • opencode/kimi-k2

要查看你可以访问哪些模型,运行 opencode models


ProviderInitError

如果你遇到 ProviderInitError,你可能有无效或损坏的配置。

要解决此问题:

  1. 首先,按照提供商指南验证你的提供商设置是否正确

  2. 如果问题仍然存在,尝试清除存储的配置:

    rm -rf ~/.local/share/opencode

    在 Windows 上,按 WIN+R 并删除:%USERPROFILE%\.local\share\opencode

  3. 在 TUI 中使用 /connect 命令重新与提供商认证。


AI_APICallError 和提供商包问题

如果你遇到 API 调用错误,这可能是由于过时的提供商包。opencode 根据需要动态安装提供商包(OpenAI、Anthropic、Google 等)并在本地缓存它们。

要解决提供商包问题:

  1. 清除提供商包缓存:

    rm -rf ~/.cache/opencode

    在 Windows 上,按 WIN+R 并删除:%USERPROFILE%\.cache\opencode

  2. 重启 opencode 以重新安装最新的提供商包

这将强制 opencode 下载最新版本的提供商包,这通常可以解决模型参数和 API 更改的兼容性问题。


Linux 上复制/粘贴不工作

Linux 用户需要安装以下剪贴板工具之一才能使复制/粘贴功能正常工作:

对于 X11 系统:

apt install -y xclip
# 或
apt install -y xsel

对于 Wayland 系统:

apt install -y wl-clipboard

对于无头环境:

apt install -y xvfb
# 并运行:
Xvfb :99 -screen 0 1024x768x24 > /dev/null 2>&1 &
export DISPLAY=:99.0

opencode 会检测你是否使用 Wayland 并优先使用 wl-clipboard,否则它会按顺序尝试查找剪贴板工具:xclipxsel