| | |
| | | Integer currentStationId) { |
| | | // 在下发新分段前检查路由版本是否仍然有效,避免在路由版本已更新的情况下下发旧版本命令 |
| | | if (!isRouteDispatchable(command == null ? null : command.getTaskNo(), command == null ? null : command.getRouteVersion())) { |
| | | // 首次校验失败可能是 Redis 写入延迟导致的,短暂等待后重试一次。 |
| | | sleepQuietly(50L); |
| | | if (!isRouteDispatchable(command == null ? null : command.getTaskNo(), command == null ? null : command.getRouteVersion())) { |
| | | if (traceRegistry != null && command != null) { |
| | | traceRegistry.markCancelled(command.getTaskNo(), traceVersion, currentStationId, |
| | | buildDetails("reason", "route_version_replaced_before_segment_send", "routeVersion", command.getRouteVersion())); |
| | |
| | | "route_version_replaced_before_segment_send"); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | while (true) { |
| | | SegmentSendResult sendResult = executeLockedSegmentSend(command, traceRegistry, traceVersion, currentStationId); |