9router/gitbook/content/vi/troubleshooting.md
2026-05-11 11:50:24 +07:00

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:

  1. Kiểm tra trạng thái quota:

    Dashboard → Providers → View quota tracker
    

    Nếu hết quota, đợi reset hoặc đổi provider.

  2. Dùng fallback combo:

    Dashboard → Combos → Create fallback chain
    Example: cc/claude-opus → glm/glm-4.7 → if/kimi-k2
    
  3. 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:

  1. Kiểm tra thời gian reset:

    Dashboard → Quota Tracking → View reset countdown
    
  2. Chuyển sang tier rẻ:

    Use: glm/glm-4.7 ($0.6/1M tokens)
         minimax/MiniMax-M2.1 ($0.20/1M tokens)
    
  3. 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:

  1. Auto-refresh (mặc định): 9Router tự refresh tokens. Đợi 30 giây rồi thử lại.

  2. Kết nối lại thủ công:

    Dashboard → Providers → [Provider Name] → Reconnect
    → Complete OAuth flow again
    
  3. 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:

  1. Kiểm tra usage stats:

    Dashboard → Usage Stats → View token consumption
    → Identify high-cost models
    
  2. 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)
    
  3. 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)
    
  4. 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:

  1. Khởi động 9Router:

    9router
    

    Dashboard sẽ mở tại http://localhost:3000

  2. Xác minh port 20128:

    # Check if port is listening
    lsof -i :20128
    
    # Or on Windows
    netstat -ano | findstr :20128
    
  3. Kiểm tra firewall:

    • macOS: System Settings → Network → Firewall
    • Windows: Windows Defender Firewall → Allow app
    • Linux: sudo ufw allow 20128
  4. 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:

  1. Kiểm tra 9Router có chạy không:

    # Check process
    ps aux | grep 9router
    
    # Check port 3000
    lsof -i :3000
    
  2. Kill process xung đột:

    # macOS/Linux
    lsof -ti:3000 | xargs kill -9
    
    # Windows
    netstat -ano | findstr :3000
    taskkill /PID <PID> /F
    
  3. Khởi động lại 9Router:

    # Stop
    pkill -f 9router
    
    # Start
    9router
    
  4. Xóa cache browser:

    • Chrome: Ctrl+Shift+Delete → Clear cache
    • Thử chế độ ẩn danh
  5. 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:

  1. Xác minh kết nối provider:

    Dashboard → Providers → Check status (green = active)
    
  2. Kiểm tra format model ID:

    Correct: cc/claude-opus-4-5-20251101
    Wrong: claude-opus-4-5-20251101
    
    Format: [provider-prefix]/[model-name]
    
  3. Liệt kê model khả dụng:

    curl http://localhost:20128/v1/models \
      -H "Authorization: Bearer your-api-key"
    
  4. 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:

  1. Kiểm tra trạng thái provider:

    Dashboard → Providers → View latency stats
    
  2. 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
    
  3. Dùng streaming:

    {
      "model": "cc/claude-opus-4-5",
      "messages": [...],
      "stream": true
    }
    
  4. Kiểm tra network:

    # Test latency
    ping api.anthropic.com
    ping api.openai.com
    
  5. 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:

  1. Tạo lại API key:

    Dashboard → Settings → API Keys → Generate New Key
    → Copy and use new key
    
  2. Xác minh format key:

    Correct: 9r_xxxxxxxxxxxxxxxxxxxxxxxx
    Wrong: Missing 9r_ prefix
    
  3. 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"
    
  4. Test API key:

    curl http://localhost:20128/v1/models \
      -H "Authorization: Bearer 9r_your_key"
    

Cần trợ giúp thêm?