6.0 KiB
6.0 KiB
失败原因统计持久化显示 - v3.13.5.7
更新日期
2025-10-12
问题描述
在批量任务执行完成后,失败原因统计信息会立即消失,用户无法查看之前执行的失败详情。
用户需求
希望失败原因统计能够一直保留显示,直到下一次开始执行新任务之前。这样用户可以:
- 在任务完成后仔细分析失败原因
- 记录和排查问题
- 决定是否需要调整配置后重试
解决方案
1. 失败原因统计的生命周期
之前的行为:
- 任务完成后,失败原因统计可能在某些情况下被意外清空
- 用户无法在任务完成后查看失败详情
新的行为:
- 任务完成后,失败原因统计保持显示
- 只有在开始新的批量任务执行时,才清空失败原因统计
- 重试模式下,失败原因统计会被保留并更新
2. 代码修改
文件:src/stores/batchTaskStore.js
修改位置:startBatchExecution 函数中的全新开始分支
} else {
// 全新开始:重置所有统计
executionStats.value = {
total: targetTokens.length,
success: 0,
failed: 0,
skipped: 0,
startTime: Date.now(),
endTime: null
}
// 🔧 v3.13.5.7: 清空失败原因统计(只在全新开始时清空)
failureReasonsStats.value = {}
if (logConfig.value.batch) console.log('🗑️ 已清空失败原因统计(开始新任务)')
}
3. 功能特性
3.1 失败原因统计的显示时机
| 场景 | 失败原因统计状态 |
|---|---|
| 任务执行中 | 实时更新显示 |
| 任务完成(有失败) | 持续显示 ✅ |
| 任务完成(全部成功) | 保持空状态 |
| 暂停任务 | 保持当前状态 |
| 继续执行 | 保持之前的统计 |
| 重试失败任务 | 保留并更新统计 |
| 开始新任务 | 清空统计 🗑️ |
| 刷新页面后恢复进度 | 从localStorage恢复 |
3.2 用户体验优化
-
任务完成后
- 失败原因统计区域持续显示
- 用户可以截图或记录失败信息
- 可以基于失败原因决定后续操作
-
开始新任务时
- 自动清空之前的失败统计
- 从零开始统计新任务的失败情况
- 控制台输出清空日志(如果启用批量日志)
-
重试模式下
- 保留原有失败统计
- 实时更新重试后的结果
- 可以对比重试前后的失败情况
4. 技术细节
4.1 清空时机(唯一触发点)
// 只在全新开始执行任务时清空
if (!continueFromSaved) {
if (isRetry) {
// 重试模式:不清空失败统计
} else {
// 全新开始:清空失败统计 ✅
failureReasonsStats.value = {}
}
}
4.2 保留时机
- 任务完成时(
completeBatchExecution):不清空 - 清除进度时(
clearSavedProgress):不清空 - 暂停任务时(
pauseBatchExecution):不清空 - 停止任务时(
stopBatchExecution):不清空
4.3 持久化存储
失败原因统计会被保存到 localStorage 中:
const progress = {
// ... 其他数据
failureReasons: currentFailureReasons // 保存失败原因统计
}
storageCache.set('batchTaskProgress', progress)
恢复时:
if (savedProgress.value.failureReasons) {
failureReasonsStats.value = savedProgress.value.failureReasons
console.log(`📊 已恢复失败原因统计`)
}
5. UI 显示效果
任务完成后的显示:
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
📋 失败原因统计(共 2 个Token失败)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
• sendCar: sendCar(服务器错误: 310060 - 未知错误): 2个Token
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
开始新任务时(如果启用日志):
🚀 开始批量执行任务
🗑️ 已清空失败原因统计(开始新任务)
6. 测试场景
6.1 基础流程
- 执行批量任务,部分Token失败
- 任务完成后,失败原因统计持续显示 ✅
- 开始新的批量任务
- 失败原因统计被清空,从零开始 ✅
6.2 重试流程
- 执行批量任务,部分Token失败
- 失败原因统计显示
- 点击"重试失败任务"
- 失败原因统计保留并实时更新 ✅
6.3 页面刷新
- 执行批量任务,部分Token失败
- 刷新页面
- 点击"继续执行"
- 失败原因统计从localStorage恢复 ✅
7. 优势
-
用户友好
- 失败信息不会突然消失
- 有足够时间分析和记录问题
-
问题排查
- 可以清楚看到哪些操作最容易失败
- 便于定位和修复系统问题
-
操作决策
- 基于失败原因决定是否重试
- 可以调整配置后再次执行
-
性能影响
- 几乎无性能开销
- 只在开始新任务时清空一次
8. 注意事项
-
失败统计的准确性
- 统计数据实时收集和更新
- 不会因为清理任务详情而丢失
-
内存占用
- 失败原因统计只保存摘要信息
- 内存占用极小(通常 < 1KB)
-
持久化存储
- 失败统计随进度保存到 localStorage
- 支持页面刷新后恢复
相关文件
src/stores/batchTaskStore.js- 批量任务状态管理src/views/DailyTasks.vue- 批量任务执行界面(显示失败统计)
版本信息
- 版本号:v3.13.5.7
- 更新类型:功能优化
- 影响范围:批量任务执行模块
后续优化建议
-
失败统计导出
- 支持将失败统计导出为文本或CSV
- 便于长期记录和分析
-
失败模式识别
- 自动识别常见失败模式
- 提供针对性的解决建议
-
历史对比
- 对比多次执行的失败情况
- 发现系统性问题