English | 中文
🚀 智能 AI API 代理中转服务平台|面向团队的多供应商统一接入、弹性调度与精细化运营中心
Claude Code Hub 通过 Next.js 15 + Hono + PostgreSQL + Redis 组合,实现 Claude/OpenAI 兼容 API 代理、智能负载均衡、实时监控、价格管理与自动化文档,帮助团队安全、可观测地管理多家 AI 服务商。
💬 加入讨论:有部署、功能或技术问题?欢迎加入 Telegram 交流群 与社区一起讨论!
- 🤖 智能负载均衡:权重 + 优先级 + 分组调度,内置熔断保护与最多 3 次故障转移,保障请求稳定。
- 🧩 多供应商管理:同时接入 Claude、Codex、Gemini CLI、OpenAI Compatible,自定义模型重定向与 HTTP/HTTPS/SOCKS 代理。
- 🛡️ 限流与并发控制:RPM、金额(5 小时/周/月)、并发 Session 多维限制,Redis Lua 脚本确保原子性与 Fail-Open 降级。
- 📘 自动化 OpenAPI 文档:39 个 REST 端点由 Server Actions 自动生成 OpenAPI 3.1.0,Swagger + Scalar UI 双界面即刻试用。
- 📊 实时监控与统计:仪表盘、活跃 Session、消耗排行榜、决策链记录、代理状态追踪,秒级掌控运行态势。
- 💰 价格表管理:分页查询 + SQL 优化,支持搜索防抖、LiteLLM 同步,千级模型也能快速检索。
- 🔁 Session 管理:5 分钟上下文缓存,记录决策链,避免频繁切换供应商并保留全链路审计。
- 🔄 OpenAI 兼容层:支持
/v1/chat/completions,自动格式转换、工具调用、reasoning 字段与 Codex CLI 指令注入。
- Docker 与 Docker Compose(推荐使用最新版本)
- 可选(本地开发):Node.js ≥ 20,pnpm ≥ 9.15
-
克隆项目并配置环境
git clone https://github.com/ding113/claude-code-hub.git cd claude-code-hub cp .env.example .env -
修改配置文件
编辑
.env文件,必须修改ADMIN_TOKEN(后台登录令牌):# 必须修改此项! ADMIN_TOKEN=your-secure-token-here # Docker Compose 默认配置(通常无需修改) DSN=postgres://postgres:postgres@postgres:5432/claude_code_hub REDIS_URL=redis://redis:6379
-
启动服务
docker compose up -d
查看启动状态:
docker compose ps docker compose logs -f app
启动成功后:
- 管理后台:
http://localhost:23000(使用.env中的ADMIN_TOKEN登录) - API 文档(Scalar UI):
http://localhost:23000/api/actions/scalar - API 文档(Swagger UI):
http://localhost:23000/api/actions/docs
💡 提示:如需修改端口,请编辑
docker-compose.yml中的ports配置。
| 功能 | 截图 | 说明 |
|---|---|---|
| 仪表盘 | ![]() |
汇总调用量、成本、活跃 Session 与时间分布,实时洞察整体使用情况。 |
| 供应商管理 | ![]() |
为每个供应商配置权重、成本系数、并发限制、代理及模型重定向,实现精细调度。 |
| 日志与审计 | ![]() |
统一查询请求日志,支持时间/用户/供应商/模型筛选,查看 Token、成本与缓冲命中情况。 |
| 排行榜 | ![]() |
按用户统计请求数、Token 与成本,用于费用分摊与用量治理。 |
客户端 / CLI / 第三方系统
│
▼
Next.js 15 App Router (v1 API 路由)
│
Hono + Proxy Pipeline (认证 → Session 分配 → 限流 → 供应商选择 → 请求转发 → 响应处理)
│
多供应商 (Claude / OpenAI / Gemini / 第三方) + PostgreSQL + Redis
- App 层:
src/app中的 dashboard、settings、api actions,提供 UI 与内部 API。 - Proxy 核心:
src/app/v1/_lib/proxy-handler.ts串联 Auth、SessionGuard、RateLimitGuard、ProviderResolver、Forwarder、ResponseHandler。 - 业务逻辑:
src/lib存放限流、Session、熔断器、代理、price-sync;src/repository封装 Drizzle ORM 查询。 - 文档体系:
src/app/api/actions/[...route]/route.ts自动注册 Action → OpenAPI 端点。
- 入口:请求携带 API Key 命中 Next.js API Route →
ProxyAuthenticator校验身份。 - 上下文管理:
SessionManager从 Redis 读取 5 分钟缓存,控制并发并记录决策链。 - 限流:
RateLimitService使用 Lua 脚本原子写入 RPM/金额/并发指标,Redis 不可用则 Fail-Open 降级。 - 调度:
ProviderResolver根据权重、优先级、熔断状态与 Session 复用策略选择最佳供应商,至多 3 次重试。 - 转发与兼容:
ProxyForwarder+ResponseTransformer适配 Claude/OpenAI/Response API,支持代理与模型重定向。 - 监控:日志、排行榜、价格表等 UI 通过
repository查询 PostgreSQL,以小时级聚合呈现指标。
Docker Compose 是首选部署方式,自动配置数据库、Redis 和应用服务,无需手动安装依赖,适合生产环境快速部署。
- 准备
.env(参考.env.example);确认DSN与REDIS_URL指向 Compose 内的服务。 - 启动:
docker compose up -d
- 查看日志与状态:
docker compose logs -f app docker compose ps
- 升级:
若需停止并清理,执行
docker compose pull && docker compose up -ddocker compose down.
- 进入
dev/目录:cd dev. make dev一键启动 PostgreSQL + Redis + pnpm dev。- 常用命令:
make db:仅启动数据库与 Redismake logs/make logs-app:快速查看服务日志make clean/make reset:清理或重置环境
- 推荐使用
make migrate、make db-shell处理数据库变更。
- 安装依赖并构建:
pnpm install pnpm build # 自动复制 VERSION - 设置环境变量(建议通过系统服务或 PM2 注入),确保数据库、Redis 可访问。
- 启动生产服务器:
pnpm start
- 注意:首次运行可开启
AUTO_MIGRATE=true自动迁移,生产环境完成后建议改为false并使用 Drizzle CLI 手动管理。
| 变量 | 默认值 | 说明与建议 |
|---|---|---|
ADMIN_TOKEN |
change-me |
后台登录令牌,部署前必须修改。 |
DSN |
- | PostgreSQL 连接串,如 postgres://user:pass@host:5432/db. |
AUTO_MIGRATE |
true |
启动时自动执行 Drizzle 迁移;生产环境可关闭以人工控制。 |
REDIS_URL |
redis://localhost:6379 |
Redis 地址,支持 rediss:// 用于 TLS。 |
ENABLE_RATE_LIMIT |
true |
控制多维限流开关;Fail-Open 策略在 Redis 不可用时自动降级。 |
SESSION_TTL |
300 |
Session 缓存时间(秒),影响供应商复用策略。 |
ENABLE_SECURE_COOKIES |
true |
仅 HTTPS 场景能设置 Secure Cookie;HTTP 访问(非 localhost)需改为 false。 |
ENABLE_CIRCUIT_BREAKER_ON_NETWORK_ERRORS |
false |
是否将网络错误计入熔断器;开启后能更激进地阻断异常线路。 |
APP_PORT |
23000 |
生产端口,可被容器或进程管理器覆盖。 |
APP_URL |
空 | 设置后 OpenAPI 文档 servers 将展示正确域名/端口。 |
布尔变量请直接写
true/false或1/0,勿加引号,避免被 Zod 转换为真值。更多字段参考.env.example。
-
数据库连接失败怎么办?
- 确认
DSN格式与凭据无误;Docker 场景下使用服务名(如postgres:5432)。 - 查看
docker compose ps或本地 PostgreSQL 状态,必要时通过make db-shell诊断。
- 确认
-
Redis 离线会影响服务吗?
- 平台采用 Fail-Open 策略:限流与会话统计会降级,但请求仍会继续;建议监控日志中的 Redis Error 并尽快恢复。
-
熔断器持续打开如何排查?
- 查看日志中的
[CircuitBreaker]记录,确认是否由于 4xx/5xx 或网络错误导致。 - 在管理后台检查供应商健康状态,等待 30 分钟或重启应用重置状态。
- 查看日志中的
-
提示“无可用供应商”该怎么办?
- 检查供应商是否启用、权重/优先级设置合理,以及是否达到并发/金额限制。
- 查看决策链日志,确认是否被熔断或代理失败导致。
-
代理配置失败?
- 确认 URL 含协议前缀(
http://、socks5://等),并使用后台“测试连接”按钮验证。 - 若启用降级策略(
proxy_fallback_to_direct),请在日志中确认是否已自动切换至直连。
- 确认 URL 含协议前缀(
欢迎通过 Issue / PR 参与开发,提交前请阅读 CONTRIBUTING.md,遵循双语目录、分支命名和 Conventional Commits 规则。
项目基于 zsio/claude-code-hub 深度改进,OpenAI 兼容层参考 router-for-me/CLIProxyAPI。感谢原作者及社区贡献者!
本项目采用 MIT License,可自由使用与二次开发,仍需遵守条款并保留致谢信息。



