7.1 KiB
Troubleshooting
Các vấn đề và giải pháp phổ biến khi dùng 9Router.
"Language model did not provide messages"
Vấn đề: Request thất bại với phản hồi rỗng hoặc thông báo lỗi.
Nguyên nhân:
- Hết quota provider
- API key không hợp lệ hoặc hết hạn
- Model không khả dụng
Giải pháp:
-
Kiểm tra trạng thái quota:
Dashboard → Providers → View quota trackerNếu hết quota, đợi reset hoặc đổi provider.
-
Dùng fallback combo:
Dashboard → Combos → Create fallback chain Example: cc/claude-opus → glm/glm-4.7 → if/kimi-k2 -
Xác minh kết nối provider:
Dashboard → Providers → Reconnect if needed
Rate Limiting
Vấn đề: Lỗi "Rate limit exceeded" hoặc "Too many requests".
Nguyên nhân:
- Hết quota subscription (giới hạn 5h/ngày/tuần)
- Đạt API rate limit
- Quá nhiều request đồng thời
Giải pháp:
-
Kiểm tra thời gian reset:
Dashboard → Quota Tracking → View reset countdown -
Chuyển sang tier rẻ:
Use: glm/glm-4.7 ($0.6/1M tokens) minimax/MiniMax-M2.1 ($0.20/1M tokens) -
Thêm fallback combo:
Dashboard → Combos → Add backup models Primary: cc/claude-opus (subscription) Backup: glm/glm-4.7 (cheap) Emergency: if/kimi-k2 (free)
OAuth Token hết hạn
Vấn đề: Lỗi "Unauthorized" hoặc "Token expired".
Nguyên nhân:
- OAuth token hết hạn (auto-refresh thất bại)
- Session provider không hợp lệ
- Vấn đề network khi refresh
Giải pháp:
-
Auto-refresh (mặc định): 9Router tự refresh tokens. Đợi 30 giây rồi thử lại.
-
Kết nối lại thủ công:
Dashboard → Providers → [Provider Name] → Reconnect → Complete OAuth flow again -
Kiểm tra trạng thái provider: Xác minh provider service đang online (Claude Code, Codex, v.v.)
Chi phí cao
Vấn đề: Sử dụng hoặc chi phí cao bất ngờ.
Nguyên nhân:
- Dùng model đắt không cần thiết
- Không fallback sang tier rẻ hơn
- Context window lớn
Giải pháp:
-
Kiểm tra usage stats:
Dashboard → Usage Stats → View token consumption → Identify high-cost models -
Chuyển sang model rẻ hơn:
Replace: cc/claude-opus ($20-100/month subscription) With: glm/glm-4.7 ($0.6/1M tokens) minimax/MiniMax-M2.1 ($0.20/1M tokens) -
Dùng free tier:
if/kimi-k2-thinking (FREE) qw/qwen3-coder-plus (FREE) kr/claude-sonnet-4.5 (FREE) gc/gemini-3-flash-preview (FREE 180K/month) -
Tối ưu prompt:
- Giảm context size
- Dùng streaming cho phản hồi dài
- Cache prompt thường dùng
Connection Refused
Vấn đề: Lỗi "ECONNREFUSED" hoặc "Cannot connect to localhost:20128".
Nguyên nhân:
- 9Router không chạy
- Port 20128 bị chặn
- Firewall chặn kết nối
Giải pháp:
-
Khởi động 9Router:
9routerDashboard sẽ mở tại http://localhost:3000
-
Xác minh port 20128:
# Check if port is listening lsof -i :20128 # Or on Windows netstat -ano | findstr :20128 -
Kiểm tra firewall:
- macOS: System Settings → Network → Firewall
- Windows: Windows Defender Firewall → Allow app
- Linux:
sudo ufw allow 20128
-
Dùng cloud endpoint: Nếu localhost không hoạt động (ví dụ: Cursor IDE):
Endpoint: https://9router.com/v1
Dashboard không mở
Vấn đề: Dashboard không load tại http://localhost:3000.
Nguyên nhân:
- Port 3000 đã được dùng
- 9Router bị crash
- Vấn đề cache browser
Giải pháp:
-
Kiểm tra 9Router có chạy không:
# Check process ps aux | grep 9router # Check port 3000 lsof -i :3000 -
Kill process xung đột:
# macOS/Linux lsof -ti:3000 | xargs kill -9 # Windows netstat -ano | findstr :3000 taskkill /PID <PID> /F -
Khởi động lại 9Router:
# Stop pkill -f 9router # Start 9router -
Xóa cache browser:
- Chrome: Ctrl+Shift+Delete → Clear cache
- Thử chế độ ẩn danh
-
Kiểm tra cài đặt firewall: Đảm bảo port 3000 không bị chặn.
Model Not Found
Vấn đề: Lỗi "Model not found" hoặc "Invalid model".
Nguyên nhân:
- Provider chưa kết nối
- Sai chính tả model ID
- Provider không hoạt động
Giải pháp:
-
Xác minh kết nối provider:
Dashboard → Providers → Check status (green = active) -
Kiểm tra format model ID:
Correct: cc/claude-opus-4-5-20251101 Wrong: claude-opus-4-5-20251101 Format: [provider-prefix]/[model-name] -
Liệt kê model khả dụng:
curl http://localhost:20128/v1/models \ -H "Authorization: Bearer your-api-key" -
Kết nối lại provider:
Dashboard → Providers → [Provider] → Reconnect
Phản hồi chậm
Vấn đề: Request mất quá lâu hoặc timeout.
Nguyên nhân:
- Độ trễ provider
- Vấn đề network
- Context/response lớn
- Provider rate limiting
Giải pháp:
-
Kiểm tra trạng thái provider:
Dashboard → Providers → View latency stats -
Chuyển sang model nhanh hơn:
Fast: cc/claude-haiku-4-5 (Haiku is faster than Opus) gc/gemini-3-flash-preview qw/qwen3-coder-flash -
Dùng streaming:
{ "model": "cc/claude-opus-4-5", "messages": [...], "stream": true } -
Kiểm tra network:
# Test latency ping api.anthropic.com ping api.openai.com -
Giảm context size:
- Cắt bớt lịch sử tin nhắn
- Dùng prompt nhỏ hơn
- Bật context pruning trong CLI tool
API Key không hợp lệ
Vấn đề: Lỗi "Invalid API key" hoặc "Authentication failed".
Nguyên nhân:
- Sao chép sai API key
- API key hết hạn
- API key chưa được tạo
Giải pháp:
-
Tạo lại API key:
Dashboard → Settings → API Keys → Generate New Key → Copy and use new key -
Xác minh format key:
Correct: 9r_xxxxxxxxxxxxxxxxxxxxxxxx Wrong: Missing 9r_ prefix -
Kiểm tra key trong CLI config:
# Cursor Settings → Models → OpenAI API Key # Cline Settings → API Key # Environment variable export OPENAI_API_KEY="9r_your_key" -
Test API key:
curl http://localhost:20128/v1/models \ -H "Authorization: Bearer 9r_your_key"
Cần trợ giúp thêm?
- GitHub Issues: github.com/decolua/9router/issues
- Documentation: 9router.com/docs
- FAQ: faq.md