Claude Code + OpenCode Go 订阅:让 Claude 跑任意开源模型
Claude Code + OpenCode Go 订阅:让 Claude 跑任意开源模型
一份给"既买了 OpenCode Go,又想用 Claude Code"的同学的实战指南。文章设计目标:小白能照着做完;AI 工具能照着帮你做完。
发布时间:待定
渠道:CSDN + 公众号
状态:草稿
写在前面
OpenCode Go 订阅($5/月起)能让你用上 GLM-5.1、Kimi K2.6、MiniMax M3、Qwen3.7-Max、DeepSeek V4 Pro 等一堆顶级开源模型。但有个问题:Claude Code 客户端默认只认 Anthropic 协议(/v1/messages),而 GLM-5.1 这些只支持 OpenAI 协议(/v1/chat/completions)。
直接配是不行的,会报 1210 / 1214 错。解决方案就是中间塞一个协议转换代理(本文用 ogc)。整篇文章 5 分钟配完,不写代码。
整体架构
┌────────────────────────────┐
│ Claude Code 客户端 │ ← 你敲命令的地方
└────────────┬───────────────┘
│ 读 ~/.claude/settings.json
│ ANTHROPIC_BASE_URL=http://127.0.0.1:3456
↓
┌────────────────────────────┐
│ ogc 代理(Go 写的本地服务)│ ← 翻译:anthropic 话 ↔ openai 话
└────────────┬───────────────┘
│ 读 ~/.config/ogc/config.json
↓
┌────────────────────────────┐
│ OpenCode Go(云端) │ ← $5/月的订阅入口
└────────────┬───────────────┘
↓
┌────────────────────────────┐
│ 上游模型(GLM-5.1/M3/...) │
└────────────────────────────┘
一句话:Claude Code 只说"anthropic 话",GLM-5.1 只懂"openai 话",ogc 就是那个翻译。
准备工作
- macOS(Linux 类似,文末备注)
- OpenCode Go 订阅 + API key(https://opencode.ai/ )
- Claude Code 客户端(
claude命令能跑) - Go 1.21+(
go version看一下,没有就brew install go)
第一步:装 ogc
go install github.com/xynogen/ogc/cmd/ogc@latest
# 加 PATH
echo 'export PATH=$PATH:$(go env GOPATH)/bin' >> ~/.zshrc
source ~/.zshrc
# 验证
ogc --version
第二步:写 ogc 配置
ogc init
会生成 ~/.config/ogc/config.json。整段替换为下面内容(API key 换成你的):
文件:~/.config/ogc/config.json
{
"api_key": "sk-你的OpenCodeGoKey",
"host": "127.0.0.1",
"port": 3456,
"models": {
"glm-5.1": {
"provider": "openai",
"model_id": "glm-5.1",
"temperature": 0.7,
"max_tokens": 8192
}
},
"model_mapping": {
"claude-opus": "glm-5.1",
"claude-sonnet": "glm-5.1",
"claude-haiku": "glm-5.1"
},
"upstream": {
"base_url": "https://opencode.ai/zen/go/v1",
"anthropic_base_url": "https://opencode.ai/zen/go/v1",
"timeout_ms": 300000
},
"logging": { "level": "info", "requests": true }
}
字段含义:
models里每个模型有provider字段,决定 ogc 用什么协议发到上游model_mapping决定 Claude 客户端的opus/sonnet/haiku三个槽位路由到哪个模型(换模型就改这一段)
模型 ↔ 协议对照表(数据来自 https://opencode.ai/docs/go/ ):
| 模型 | ogc provider |
|---|---|
| minimax-m3 / m2.7 / m2.5 | anthropic |
| qwen3.7-max / qwen3.7-plus / qwen3.6-plus / qwen3.5-plus | anthropic |
| glm-5.1 / glm-5 | openai |
| kimi-k2.5 / kimi-k2.6 | openai |
| mimo-v2-pro / mimo-v2-omni / mimo-v2.5-pro / mimo-v2.5 | openai |
| deepseek-v4-pro / deepseek-v4-flash | openai |
第三步:先前台跑一下验证
ogc serve
看到 Listening on 127.0.0.1:3456 就 OK。另开一个终端测一下:
curl -X POST http://127.0.0.1:3456/v1/messages \
-H "x-api-key: dummy" \
-H "anthropic-version: 2023-06-01" \
-H "content-type: application/json" \
-d '{"model":"claude-sonnet-4-5","max_tokens":15,"messages":[{"role":"user","content":"reply OK"}]}'
返回 200 + 一段 JSON 就说明通了。Ctrl+C 停掉前台。
第四步:开机自启
# 生成 plist
ogc autostart enable
# 加上 API key(plist 默认不带)
/usr/libexec/PlistBuddy \
-c "Add :EnvironmentVariables:OGC_API_KEY string sk-你的OpenCodeGoKey" \
~/Library/LaunchAgents/com.xynogen.ogc.plist
# 加载 plist
launchctl load -w ~/Library/LaunchAgents/com.xynogen.ogc.plist
# 验证
lsof -nP -iTCP:3456 -sTCP:LISTEN
第五步:改 Claude Code 客户端配置
文件:~/.claude/settings.json
在 "env" 段加上下面的字段(如果没 "env" 就加):
"env": {
"ANTHROPIC_BASE_URL": "http://127.0.0.1:3456",
"ANTHROPIC_API_KEY": "unused",
"ANTHROPIC_MODEL": "glm-5.1",
"ANTHROPIC_DEFAULT_HAIKU_MODEL": "glm-5.1",
"ANTHROPIC_DEFAULT_OPUS_MODEL": "glm-5.1",
"ANTHROPIC_DEFAULT_SONNET_MODEL": "glm-5.1"
}
⚠️ 三个易错点:
- 字段名是
ANTHROPIC_API_KEY,不是ANTHROPIC_AUTH_TOKEN ANTHROPIC_BASE_URL不带/v1(SDK 会自动加)ANTHROPIC_API_KEY写"unused"就行,ogc 不检查
第六步:启动 Claude
claude --dangerously-skip-permissions
发条消息(比如"你好"),看到回复 = 全部搞定。
换模型的标准操作(SOP)
以后想换模型,按这 4 步走。以"glm-5.1 → minimax-m3"为例:
# 1) 备份
cp ~/.config/ogc/config.json ~/.config/ogc/config.json.bak.$(date +%H%M%S)
# 2) 改 JSON(用 Python 不容易写错)
python3 << 'PYEOF'
import json
p = '/Users/bryle/.config/ogc/config.json'
d = json.load(open(p))
# 加新模型(注意 provider 字段:查上面对照表)
d['models']['minimax-m3'] = {
"provider": "anthropic", # minimax-m3 走 anthropic
"model_id": "minimax-m3",
"temperature": 0.7,
"max_tokens": 65536,
}
# 改路由(claude-*/sonnet/haiku 都指向新模型)
d['model_mapping'] = {
"claude-opus": "minimax-m3",
"claude-sonnet": "minimax-m3",
"claude-haiku": "minimax-m3",
}
json.dump(d, open(p, 'w'), indent=2, ensure_ascii=False)
print("已改")
PYEOF
# 3) 验证 + 重启 ogc
ogc validate
launchctl unload ~/Library/LaunchAgents/com.xynogen.ogc.plist
launchctl load -w ~/Library/LaunchAgents/com.xynogen.ogc.plist
sleep 2
lsof -nP -iTCP:3456 -sTCP:LISTEN
# 4) 开新的 claude 会话(旧会话的 context 还绑着旧模型)
claude --dangerously-skip-permissions
核心就一句话:加菜 + 改路由 + 重启 ogc + 开新会话。
故障排查速查表
| 错误 | 原因 | 解决 |
|---|---|---|
| Both a token and an API key are set | settings.json 同时有 AUTH_TOKEN 和 API_KEY |
sed -i '' 's/"ANTHROPIC_AUTH_TOKEN"/"ANTHROPIC_API_KEY"/g' ~/.claude/settings.json |
| 401 AuthError / Missing API key | 用了 ANTHROPIC_AUTH_TOKEN(OAuth 头 Bearer) |
改用 ANTHROPIC_API_KEY(API key 头 x-api-key) |
| 1210 / 1214 “Error from provider (Z.ai)” | 模型协议配错了(GLM 配成了 anthropic) | 改 ogc config 的 provider 字段 |
| 404 Page Not Found | base_url 带了 /v1 |
改成 https://opencode.ai/zen/go |
| ogc 进程不在了 | 没人保活 | launchctl kickstart -k gui/$(id -u)/com.xynogen.ogc |
不想用 ogc?也行
如果只用 anthropic 协议的模型(minimax-m3、qwen3.x),可以直连 OpenCode Go,连 ogc 都不用装:
"env": {
"ANTHROPIC_BASE_URL": "https://opencode.ai/zen/go",
"ANTHROPIC_API_KEY": "sk-你的Key",
"ANTHROPIC_MODEL": "qwen3.7-max"
}
但想用 GLM-5.1 / Kimi / DeepSeek 这些,必须用 ogc 或同类工具做协议转换。
写在最后
整个方案就是一句话的事:Claude Code 说人话,部分模型说机器话,中间需要个翻译。剩下的就是改 JSON 文件、跑几个命令。
5 分钟搞定,以后换模型 30 秒搞定。Happy hacking 🚀
Linux 用户备注:把 ~/Library/LaunchAgents/ 换成 ~/.config/systemd/user/,plist 换成 systemd unit(ogc serve --background 就行)。其他完全一样。
更多推荐


所有评论(0)