lzh
b534d79434
fix(ops): 派发入口加 FOR UPDATE 并发兜底,冲突时降级入队避免悬空
业务不变量:同一执行人在任一时刻最多只有 1 条活跃工单
(DISPATCHED/CONFIRMED/ARRIVED)。PAUSED 不纳入——P0 打断恢复
走 PAUSED→DISPATCHED,此处必须放行。
实现:
1. OpsOrderMapper.selectActiveByAssigneeForUpdate
查询 assignee 活跃工单并对命中行加 FOR UPDATE 排他锁。必须在
事务中调用。
2. OrderLifecycleManagerImpl.dispatch 入口校验
事务开启后立即执行 FOR UPDATE 查询,命中则返回带错误码
ASSIGNEE_HAS_ACTIVE_ORDER 的失败结果,不再执行责任链,
事务 commit 空操作、锁释放;并发竞争的第二个线程会阻塞到
第一个 commit 后看到活跃单,失败退出。
3. 新增 TransitionErrorCode 枚举 + OrderTransitionResult.errorCode
调用方可区分需降级的冲突与硬失败,避免把"可降级"的结果
直接抛给用户。
4. DispatchEngineImpl.executeDirectDispatch 降级逻辑
- 冲突 + 原状态 PENDING → 调 executeEnqueueOnly 降级到 QUEUED,
工单不悬空,等下一轮 autoDispatchNext 重挑。
- 冲突 + 原状态已是 QUEUED(并发另一路抢先派发时回滚保留)
→ 返回 fail 但不重复入队,天然等下一轮。
- 其他失败 → 照常 fail。
职责划分:
- 生命周期层负责"拒绝违反不变量的转换"
- 编排层负责"失败后给工单安置归宿"
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-04-20 11:52:38 +08:00
..
2026-04-20 10:54:54 +08:00
2025-12-31 16:49:44 +08:00
2026-04-13 23:18:30 +08:00
2026-04-20 11:52:38 +08:00
2026-04-05 15:26:43 +08:00
2026-03-27 16:37:30 +08:00
2025-12-31 16:49:44 +08:00
2025-12-31 16:49:44 +08:00