docs/operations/troubleshooting.zh.md
返回 README
症状: 你看到以下任一错误:
Error creating provider: model "openrouter/free" not found in model_list"free is not a valid model ID"原因: PicoClaw 现在按两步解析 provider 和 model:
provider,则会把 model 原样发送给该 provider。provider,则会把 model 第一个 / 之前的字段当作 provider,并把第一个 / 之后的全部内容当作最终发送的模型 ID。对于 OpenRouter 免费层路由,推荐显式设置 provider。
"model": "free" → 不会选中 OpenRouter,free 也不是可直接路由的 OpenRouter 模型配置。"provider": "openrouter", "model": "free" → OpenRouter 收到 free。"model": "openrouter/free" → provider 解析为 openrouter,最终模型 ID 解析为 free。修复方法: 在 ~/.picoclaw/config.json(或你的配置路径)中:
model_list 中的某个 model_name(例如 "openrouter-free")。openrouter,并在 model 中填写有效的 OpenRouter 模型 ID,例如:
"free" – 自动免费层"google/gemini-2.0-flash-exp:free""meta-llama/llama-3.1-8b-instruct:free"示例片段:
{
"agents": {
"defaults": {
"model_name": "openrouter-free"
}
},
"model_list": [
{
"model_name": "openrouter-free",
"provider": "openrouter",
"model": "free",
"api_keys": ["sk-or-v1-YOUR_OPENROUTER_KEY"],
"api_base": "https://openrouter.ai/api/v1"
}
]
}
在 OpenRouter Keys 获取你的密钥。