ianshaw
25b00abca1
fix(网关): 修复账号选择中的调度器快照延迟问题
## 问题描述
调度器快照更新存在0.5-1秒的延迟(Outbox轮询间隔),导致在账号被限流或过载后的短时间窗口内,
可能仍会被选中,造成请求失败。
## 根本原因
账号选择逻辑依赖调度器快照(listSchedulableAccounts),但快照更新有延迟:
- Outbox轮询: 每1秒检查一次变更事件
- 全量重建: 每300秒重建一次
- 时间窗口: 账号状态变更后0.5-1秒内,快照可能未更新
## 解决方案
在账号选择循环中添加IsSchedulable()实时检查,作为第二道防线:
1. 第一道防线: 调度器快照过滤(可能有延迟)
2. 第二道防线: IsSchedulable()实时检查(本次修复)
IsSchedulable()会检查:
- RateLimitResetAt: 限流重置时间
- OverloadUntil: 过载持续时间
- TempUnschedulableUntil: 临时不可调度时间
- Status: 账号状态
- Schedulable: 可调度标志
## 修改范围
### OpenAI Gateway Service
- SelectAccountForModelWithExclusions: 添加IsSchedulable()检查
- SelectAccountWithLoadAwareness: 添加IsSchedulable()检查
### Gateway Service (Claude/Gemini/Antigravity)
- 负载感知选择候选账号筛选: 添加IsSchedulable()检查
- selectAccountForModelWithPlatform: 添加IsSchedulable()检查
- selectAccountWithMixedScheduling: 添加IsSchedulable()检查
### 测试用例
- OpenAI: 添加2个测试用例验证限流账号过滤
- Gateway: 添加2个测试用例验证限流和过载账号过滤
### 其他修复
- ops_repo_preagg.go: 修复platform为NULL时的聚合问题
## 测试结果
所有单元测试通过 ✅
2026-01-13 22:49:26 -08:00
..
2026-01-04 19:28:20 +08:00
2026-01-12 14:19:06 +08:00
2026-01-04 19:28:20 +08:00
2026-01-03 06:37:08 -08:00
2026-01-03 06:37:08 -08:00
2026-01-10 22:23:51 +08:00
2026-01-04 19:28:20 +08:00
2026-01-10 22:23:51 +08:00
2025-12-25 17:15:01 +08:00
2025-12-26 16:47:44 +08:00
2025-12-26 16:47:44 +08:00
2026-01-03 06:36:35 -08:00
2026-01-04 22:10:32 +08:00
2026-01-04 21:06:12 +08:00
2026-01-03 10:52:24 +08:00
2026-01-01 04:01:51 +08:00
2026-01-03 06:32:51 -08:00
2026-01-09 20:52:57 +08:00
2026-01-12 10:53:41 +08:00
2026-01-11 15:00:16 +08:00
2026-01-11 15:00:16 +08:00
2025-12-31 23:42:01 +08:00
2025-12-31 23:42:01 +08:00
2025-12-25 17:15:01 +08:00
2025-12-26 16:47:44 +08:00
2025-12-26 16:47:44 +08:00
2026-01-05 22:24:24 +08:00
2025-12-31 23:42:01 +08:00
2026-01-04 19:28:20 +08:00
2026-01-08 23:25:05 +08:00
2026-01-08 23:07:00 +08:00
2025-12-30 16:41:45 +08:00
2026-01-08 23:47:29 +08:00
2025-12-26 00:11:03 -08:00
2025-12-31 08:50:12 +08:00
2026-01-07 23:15:20 +08:00
2026-01-07 23:15:20 +08:00
2026-01-10 09:39:02 +08:00
2026-01-12 14:19:06 +08:00
2026-01-04 11:43:58 +08:00
2026-01-04 21:06:12 +08:00
2026-01-05 13:54:43 +08:00
2025-12-25 17:15:01 +08:00
2025-12-26 16:47:44 +08:00
2025-12-26 16:47:44 +08:00
2026-01-03 06:36:35 -08:00
2025-12-31 23:42:01 +08:00
2026-01-12 14:19:06 +08:00
2026-01-05 14:07:33 +08:00
2026-01-03 06:36:35 -08:00
2025-12-31 08:50:12 +08:00
2026-01-11 23:26:29 +08:00
2026-01-12 17:06:12 +08:00
2026-01-11 23:49:03 +08:00
2026-01-09 20:52:57 +08:00
2026-01-11 23:57:20 +08:00
2026-01-11 23:49:03 +08:00
2026-01-13 22:49:26 -08:00
2026-01-12 14:17:42 +08:00
2026-01-11 23:57:20 +08:00
2026-01-12 17:06:12 +08:00
2026-01-09 20:52:57 +08:00
2026-01-12 17:06:12 +08:00
2025-12-26 16:45:40 +08:00
2026-01-07 23:15:20 +08:00
2026-01-07 23:15:20 +08:00
2026-01-10 13:14:35 +08:00
2026-01-04 21:06:12 +08:00
2026-01-06 11:36:38 +08:00
2025-12-29 19:23:49 +08:00
2026-01-08 21:20:12 +08:00
2025-12-26 16:47:44 +08:00
2025-12-26 16:47:44 +08:00
2025-12-26 16:47:44 +08:00
2025-12-29 19:23:49 +08:00
2025-12-31 14:11:57 +08:00
2025-12-31 23:42:01 +08:00
2025-12-31 23:42:01 +08:00
2025-12-31 14:51:58 +08:00
2026-01-12 14:19:06 +08:00
2026-01-12 15:46:55 +08:00
2026-01-12 15:46:55 +08:00
2025-12-31 15:52:02 +08:00
2025-12-29 10:03:27 +08:00
2026-01-04 19:28:20 +08:00
2025-12-30 17:13:32 +08:00
2026-01-03 06:34:00 -08:00
2026-01-11 21:54:52 -08:00
2026-01-03 06:36:35 -08:00
2026-01-03 10:52:24 +08:00
2025-12-25 16:01:17 +08:00
2025-12-25 17:15:01 +08:00
2026-01-12 09:23:46 +08:00
2026-01-11 18:20:15 +08:00
2026-01-01 19:09:06 +08:00
2026-01-05 19:03:54 +08:00
2026-01-05 18:48:49 +08:00
2025-12-31 22:48:35 +08:00
2025-12-31 22:48:35 +08:00
2026-01-12 14:50:53 +08:00