Files
xyzw_web_helper/MD说明文件夹/性能优化-发车超时统一1000ms v3.11.6.md

269 lines
7.9 KiB
Markdown
Raw Normal View History

2025-10-17 20:56:50 +08:00
# 性能优化发车超时统一1000ms v3.11.6
## 📋 更新时间
2025-10-08
## 🎯 优化目标
将批量自动化中"发车"任务的所有超时时间统一调整为 **1000ms**,测试是否可行,提升任务执行速度。
## 📊 修改前后对比
### 修改前配置v3.11.5
| 操作步骤 | WebSocket命令 | 超时时间 | 说明 |
|---------|--------------|---------|------|
| 1⃣ 查询车辆 | `car_getrolecar` | **10000ms** (10秒) | 查询俱乐部车辆信息 |
| 2⃣ 批量刷新 | `car_refresh` | **5000ms** (5秒) | 刷新每辆车 |
| 3⃣ 批量收获 | `car_claim` | **5000ms** (5秒) | 收获已到达的车辆 |
| 4⃣ 批量发送 | `car_send` | **5000ms** (5秒) | 发送待发车的车辆 |
| 5⃣ 最终验证 | `car_getrolecar` | **10000ms** (10秒) | 验证最终发车数 |
**预估单次发车时间:** 约 10-30秒
### 修改后配置v3.11.6
| 操作步骤 | WebSocket命令 | 超时时间 | 说明 |
|---------|--------------|---------|------|
| 1⃣ 查询车辆 | `car_getrolecar` | **1000ms** (1秒) ⬇️ | 查询俱乐部车辆信息 |
| 2⃣ 批量刷新 | `car_refresh` | **1000ms** (1秒) ⬇️ | 刷新每辆车 |
| 3⃣ 批量收获 | `car_claim` | **1000ms** (1秒) ⬇️ | 收获已到达的车辆 |
| 4⃣ 批量发送 | `car_send` | **1000ms** (1秒) ⬇️ | 发送待发车的车辆 |
| 5⃣ 最终验证 | `car_getrolecar` | **1000ms** (1秒) ⬇️ | 验证最终发车数 |
**预估单次发车时间:** 约 3-8秒 ⬇️ **减少70%**
## ✨ 优化效果
### 时间节省
| 场景 | 修改前 | 修改后 | 节省时间 |
|------|--------|--------|---------|
| **单次发车4辆车** | 10-30秒 | 3-8秒 | **节省 7-22秒** |
| **21个Token批量并发3** | 约3-5分钟 | 约1-2分钟 | **节省 2-3分钟** |
| **100个Token批量并发5** | 约15-25分钟 | 约5-8分钟 | **节省 10-17分钟** |
### 性能提升
1.**执行速度提升 70%**:发车任务执行时间大幅缩短
2.**响应更快**:用户体验更流畅
3.**吞吐量提升**相同时间内可处理更多token
4.**统一配置**:所有发车操作使用相同超时,便于维护
## 🔧 代码修改
### 修改的文件
`src/stores/batchTaskStore.js`
### 修改内容
#### 1⃣ 查询车辆第1180行
```javascript
// 修改前
const response = await tokenStore.sendMessageAsync(tokenId, 'car_getrolecar', {}, 10000)
// 修改后
const response = await tokenStore.sendMessageAsync(tokenId, 'car_getrolecar', {}, 1000)
```
#### 2⃣ 批量刷新第1297行
```javascript
// 修改前
await tokenStore.sendMessageAsync(tokenId, 'car_refresh', { carId: carId }, 5000)
// 修改后
await tokenStore.sendMessageAsync(tokenId, 'car_refresh', { carId: carId }, 1000)
```
#### 3⃣ 批量收获第1363行
```javascript
// 修改前
await tokenStore.sendMessageAsync(tokenId, 'car_claim', { carId: carId }, 5000)
// 修改后
await tokenStore.sendMessageAsync(tokenId, 'car_claim', { carId: carId }, 1000)
```
#### 4⃣ 批量发送第1463行
```javascript
// 修改前
await tokenStore.sendMessageAsync(tokenId, 'car_send', {
carId: carId,
helperId: 0,
text: ""
}, 5000)
// 修改后
await tokenStore.sendMessageAsync(tokenId, 'car_send', {
carId: carId,
helperId: 0,
text: ""
}, 1000)
```
#### 5⃣ 最终验证queryClubCars 函数复用已包含在第1180行修改中
## ⚠️ 注意事项
### 可能的风险
1. **超时风险**
- 网络较慢时1000ms 可能不足以完成请求
- 服务器响应慢时,可能出现超时错误
- 高并发时,服务器压力大可能导致超时
2. **失败处理**
- 如果频繁超时,自动重试机制会生效
- 部分任务失败会触发整体任务重试
3. **适用场景**
- ✅ 网络状况良好
- ✅ 服务器响应快速
- ✅ 并发数适中≤10
- ❌ 网络不稳定
- ❌ 服务器负载高
- ❌ 超高并发(>20
### 监控建议
在使用新配置时,请注意观察:
1. **成功率**
- 发车任务成功率是否下降
- 是否出现频繁的超时错误
2. **重试频率**
- 自动重试是否频繁触发
- 重试后成功率如何
3. **日志信息**
```
✅ 正常:[token_xxx] 查询车辆成功 (在1000ms内)
⚠️ 警告:请求超时: car_getrolecar (1000ms)
🔄 重试自动重试失败任务第1/3轮
```
## 🧪 测试建议
### 测试场景1正常网络环境
1. 运行批量自动化选择3-5个token
2. 启用"发车"任务
3. 观察:
- ✅ 发车任务是否快速完成3-8秒
- ✅ 是否有超时错误
- ✅ 最终发车数是否准确4/4
### 测试场景2高并发环境
1. 运行批量自动化选择10-20个token
2. 设置并发数为10
3. 观察:
- ✅ 发车任务成功率
- ⚠️ 是否出现超时错误增加
- 📊 整体完成时间对比
### 测试场景3网络较慢环境
1. 在网络不佳时运行批量自动化
2. 观察:
- ⚠️ 超时错误频率
- 🔄 重试机制是否有效
- 💡 是否需要恢复更长的超时时间
## 📈 性能数据记录
### 建议记录的指标
| 指标 | 修改前 | 修改后 | 改进 |
|------|--------|--------|------|
| 单次发车平均时间 | ___秒 | ___秒 | ___% |
| 发车任务成功率 | ___% | ___% | ___% |
| 超时错误频率 | ___次/100次 | ___次/100次 | ___次 |
| 重试触发频率 | ___% | ___% | ___% |
**请在实际使用中填写,以评估优化效果**
## 🔄 回滚方案
如果新配置导致频繁超时或成功率下降,可以恢复为原配置:
### 方案A仅恢复查询和验证推荐
```javascript
// 查询车辆和最终验证
car_getrolecar: 1000ms → 5000ms
// 刷新、收获、发送保持1000ms
car_refresh: 1000ms
car_claim: 1000ms
car_send: 1000ms
```
### 方案B全部恢复保守
```javascript
car_getrolecar: 1000ms → 10000ms
car_refresh: 1000ms → 5000ms
car_claim: 1000ms → 5000ms
car_send: 1000ms → 5000ms
```
### 方案C折中配置平衡
```javascript
// 所有操作统一为3000ms
car_getrolecar: 1000ms → 3000ms
car_refresh: 1000ms → 3000ms
car_claim: 1000ms → 3000ms
car_send: 1000ms → 3000ms
```
## 💡 未来优化方向
1. **自适应超时**
- 根据历史响应时间动态调整超时
- 网络慢时自动延长,网络快时自动缩短
2. **并发优化**
- 根据超时频率动态调整并发数
- 超时率高时自动降低并发
3. **错误重试优化**
- 超时错误使用更短的重试间隔
- 其他错误使用标准重试间隔
4. **配置UI化**
- 允许用户在设置中自定义超时时间
- 提供"快速/标准/保守"预设模式
## 🔗 相关文档
- [批量自动化-超时延迟配置表v3.11.md](./批量自动化-超时延迟配置表v3.11.md)
- [功能优化-发车任务最终验证v3.11.3.md](./功能优化-发车任务最终验证v3.11.3.md)
- [问题修复-部分任务失败触发重试v3.11.4.md](./问题修复-部分任务失败触发重试v3.11.4.md)
## 📝 版本历史
### v3.11.6 (2025-10-08)
- ⚡ 性能优化发车任务所有超时时间统一调整为1000ms
- 📊 预期效果任务执行速度提升70%
- 🔄 说明:统一超时配置,便于维护和调整
### v3.11.5 (2025-10-08)
- 🐛 修复答题任务3100080错误处理
### v3.11.4 (2025-10-08)
- 🐛 修复:部分任务失败触发重试
### v3.11.3 (2025-10-08)
- ✨ 新增:发车任务最终验证步骤
---
## 🎉 总结
此次优化将发车任务的超时时间统一调整为 **1000ms**,预期可将发车任务执行时间缩短 **70%**
**建议:**
- ✅ 先在小规模3-5个token测试
- ✅ 观察成功率和超时频率
- ✅ 根据实际情况决定是否需要调整
- ⚠️ 如遇频繁超时,请参考回滚方案
**反馈:** 请在使用后提供实际效果反馈,以便进一步优化!