mirror of
https://codeup.aliyun.com/67c68d4e484ca2f0a13ac3c1/ydc/jsowell-charger-web.git
synced 2026-06-22 08:09:48 +08:00
14 KiB
14 KiB
mode, cwd, task, complexity, planning_method, created_at
| mode | cwd | task | complexity | planning_method | created_at |
|---|---|---|---|---|---|
| plan | /Users/guoqiusi/Workspace/jsowell-charger-web | 云快充1.6协议凌晨离线问题修复与协议对齐 | high | builtin | 2026-03-21T08:48:24+08:00 |
Plan: 云快充1.6凌晨离线修复跟踪
任务概述
当前项目中,云快充 1.6 协议设备在凌晨时段存在离线现象。经代码与协议文档对照,未发现明确的“凌晨主动断链”定时任务,更可能是夜间网络/SIM 抖动触发了当前偏激进的离线判定逻辑,导致短时弱网被放大为设备离线。
本计划用于跟踪以下三类工作:
- 先止血:降低“短时抖动即离线”的敏感度。
- 再纠偏:按协议修正登录、心跳、费率、对时流程。
- 最后收敛:统一实现入口,减少后续维护风险。
关键结论
- 协议要求:
0x03心跳为 10 秒周期上送,连续 3 次未收到才视为网络异常并重新登录。0x13实时监测数据周期上送,待机 5 分钟、充电 15 秒。0x05 -> 0x06 -> 0x09 -> 0x0A为费率模型校验与拉取闭环。0x56对时为 1 天周期发送。
- 当前实现中的高风险点:
- Netty 读空闲 30 秒即触发关闭连接。
- 断链后立即将枪口置离线,并将充电中订单改异常。
- 桩状态按“任意枪口离线即整桩离线”计算。
0x05校验请求当前固定返回“一致”,未真正校验费率模型。- 登录后主动下发
0x58,与协议标准流程不完全一致。 - 对时仅在登录后发送一次,未发现每日自动对时任务。
- 线上实际走老 Handler 链路,新 Strategy 链路当前不生效。
目标与验收口径
业务目标
- 凌晨
00:00-06:00时段,短时网络抖动不再导致桩状态频繁离线。 - 单次
30-40s的弱网抖动不应直接把充电中订单改为异常。 - 桩在线状态与真实链路状态更一致,减少前端“在线/离线闪断”。
协议目标
0x03按协议节奏与容错逻辑处理。0x05/0x06/0x09/0x0A恢复为真实校验与请求链路。0x56/0x55具备每日自动对时能力和执行记录。
验收标准
- 短时网络抖动:
- 30-40 秒无上行数据后恢复,不直接离线。
- 宽限期内重连成功,不产生订单异常。
- 长时网络中断:
- 超出配置阈值后,设备进入离线状态。
- 若有正在充电订单,按规则进入异常处理。
- 协议链路:
- 桩上报旧费率模型时,平台能正确返回不一致并等待
0x09请求。 - 每日自动对时后,可看到
0x55应答记录。
- 桩上报旧费率模型时,平台能正确返回不一致并等待
- 排障能力:
- 日志能够还原“最后正常通信 -> 空闲超时 -> 关闭连接 -> 是否重连成功”的完整链路。
执行批次
第一批:先止血
- 调整 Netty 空闲断链策略。
- 引入断链宽限期,避免瞬断即离线。
- 补连接生命周期日志。
- 修复 channel 映射清理。
第二批:协议纠偏
- 修复费率模型校验与拉取闭环。
- 新增每日自动对时。
- 将关键阈值配置化。
第三批:实现收敛
- 收敛云快充双实现,只保留一条实际生效链路。
- 补齐专项回归验证与联调记录。
任务清单
YKC-001
- 优先级:P0
- 状态:todo
- 目标:将云快充连接保活从“30 秒空闲直接断开”改为“允许短时抖动,按连续丢心跳或宽限期判定断链”。
- 修改文件:
/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServerChannelInitializer.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServerHandler.java
- 设计要点:
IdleStateHandler读空闲阈值调整为40-45s或等效容错值。userEventTriggered不再第一次超时就close()。- 结合最近通信时间和连续空闲次数处理。
- 验收标准:
- 单次
30-40s无上行数据不直接断链。 - 凌晨弱网时连接不会频繁抖动为离线。
- 单次
- 风险:
- 阈值过宽会延迟真实离线发现,需要与业务确认容忍度。
YKC-002
- 优先级:P0
- 状态:todo
- 目标:增加“断链宽限期”,避免瞬断立刻将枪口置离线、订单置异常。
- 修改文件:
/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/service/yunkuaichong/impl/YKCBusinessServiceImpl.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-pile/src/main/java/com/jsowell/pile/service/impl/OrderBasicInfoServiceImpl.java
- 设计要点:
exit()中先记录“断链待确认”状态。- 宽限期结束且未恢复登录时,才正式落离线和订单异常。
- 若宽限期内重连,取消离线确认。
- 验收标准:
- 短时断链后在宽限期内重连,不产生订单异常。
- 真正长断链后仍能正确离线。
- 风险:
- 需防止宽限期任务重复执行或状态竞争。
YKC-003
- 优先级:P0
- 状态:todo
- 目标:补齐连接生命周期日志,支持“凌晨离线”专项排查。
- 修改文件:
/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServerHandler.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/handler/yunkuaichong/HeartbeatRequestHandler.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/handler/yunkuaichong/LoginRequestHandler.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/handler/yunkuaichong/UploadRealTimeMonitorHandler.java
- 设计要点:
- 统一打印
pileSn、channelId、远端 IP、最后一帧类型、最后上报时间、IdleState 类型、重连耗时。 - 对凌晨时段日志加清晰关键词,便于筛查。
- 统一打印
- 验收标准:
- 一次离线事件能从日志完整还原链路。
- 风险:
- 需控制日志量,避免高频心跳刷爆日志。
YKC-004
- 优先级:P0
- 状态:todo
- 目标:修复 channel 映射清理不完整的问题,避免旧连接残留。
- 修改文件:
/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/service/yunkuaichong/impl/YKCBusinessServiceImpl.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-common/src/main/java/com/jsowell/common/enums/ykc/PileChannelEntity.java
- 设计要点:
- 恢复
removeByPileSn/removeByChannelId的正常调用。 - 确保断链、异常、重连时旧
channel被清理。
- 恢复
- 验收标准:
- 同一桩重连后只保留一个有效
channel。 - 下行命令不会打到死连接。
- 同一桩重连后只保留一个有效
- 风险:
- 需避免误删新连接。
YKC-005
- 优先级:P1
- 状态:todo
- 目标:将桩离线判定从“任意枪状态为离线即整桩离线”改为“最近通信时间 + 枪状态 + 宽限期”的综合判定。
- 修改文件:
/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-pile/src/main/java/com/jsowell/pile/service/impl/PileConnectorInfoServiceImpl.java
- 设计要点:
getPileStatus/getPileStatusV2/checkPileOffLine使用统一判定逻辑。- 将固定 3 分钟阈值改为可配置。
- 验收标准:
- 前端在线状态与真实通信状态一致。
- 短时抖动不出现整桩离线闪断。
- 风险:
- 旧缓存与新判定逻辑可能短期不一致,需要同步清理策略。
YKC-006
- 优先级:P1
- 状态:todo
- 目标:按协议修正费率模型交互,去掉“固定返回一致”的实现。
- 修改文件:
/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/handler/yunkuaichong/BillingTemplateValidateRequestHandler.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/handler/yunkuaichong/BillingTemplateRequestHandler.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/handler/yunkuaichong/LoginRequestHandler.java
- 设计要点:
0x05真比较平台模型号与桩上报模型号。- 不一致返回
0x01。 - 由桩继续发
0x09,平台回0x0A。 - 登录后主动
0x58改为开关控制或移除。
- 验收标准:
- 费率模型链路符合协议。
- 跨天费率切换时行为可解释、可追踪。
- 风险:
- 需确认现网桩程序是否依赖“登录后强推模板”的兼容行为。
YKC-007
- 优先级:P1
- 状态:todo
- 目标:补每日自动对时,降低跨天时钟漂移的影响。
- 修改文件:
/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-pile/src/main/java/com/jsowell/pile/service/impl/YKCPushCommandServiceImpl.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/handler/yunkuaichong/TimeCheckSettingResponseHandler.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-quartz/src/main/java/com/jsowell/quartz/task/JsowellTask.java
- 设计要点:
- 每日定时给在线桩批量发
0x56。 - 记录
0x55应答结果与桩回传时间。
- 每日定时给在线桩批量发
- 验收标准:
- 每日有自动对时执行记录。
- 对时失败可重试,可观测。
- 风险:
- 大批量对时可能集中打到凌晨,需控制任务节奏。
YKC-008
- 优先级:P1
- 状态:todo
- 目标:将关键超时和离线参数配置化,避免硬编码。
- 修改文件:
/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServerChannelInitializer.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-pile/src/main/java/com/jsowell/pile/service/impl/PileConnectorInfoServiceImpl.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-admin/src/main/resources/application.yml
- 设计要点:
- 至少抽出:
readerIdleSecondsofflineConfirmSecondslastConnectionOfflineMinutesdailyTimeSyncCron
- 至少抽出:
- 验收标准:
- 不改代码即可在环境配置中调整离线策略。
- 风险:
- 需注意各环境默认值兼容。
YKC-009
- 优先级:P2
- 状态:todo
- 目标:收敛云快充双实现,避免后续修错入口。
- 修改文件:
/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/service/yunkuaichong/impl/YKCBusinessServiceImpl.java/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/handler/yunkuaichong/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/strategy/ykc
- 设计要点:
- 确认唯一线上入口。
- 如果保留老 Handler,则冻结或移除 Strategy。
- 如果迁移到 Strategy,则需一次性迁完。
- 验收标准:
- 线上只存在一套实际生效的云快充处理链路。
- 风险:
- 涉及面较大,需单独回归。
YKC-010
- 优先级:P1
- 状态:todo
- 目标:补专项回归验证和凌晨专项验证脚本或测试用例。
- 修改文件:
/Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-admin/src/test/java
- 设计要点:
- 覆盖场景:
30-40s无心跳但恢复。- 宽限期内重连。
- 费率模型不一致重新请求。
- 每日对时成功和失败。
- 覆盖场景:
- 验收标准:
- 每个修复点至少有一条可复现、可回归的验证路径。
- 风险:
- 若缺真实协议模拟器,需先补测试桩或伪报文能力。
推荐执行顺序
- YKC-001
- YKC-002
- YKC-003
- YKC-004
- YKC-005
- YKC-008
- YKC-006
- YKC-007
- YKC-010
- YKC-009
文件级改造备注
连接与断链主链路
NettyServerChannelInitializer- 负责 IdleState 参数配置。
NettyServerHandler- 负责空闲事件、异常事件、连接关闭事件的断链控制。
YKCBusinessServiceImpl- 负责断链后离线和订单状态变更逻辑。
在线状态与业务影响主链路
PileChannelEntity- 管理桩与 channel 的映射。
PileConnectorInfoServiceImpl- 管理枪口状态、桩状态聚合与前端在线判断。
OrderBasicInfoServiceImpl- 管理充电订单异常状态的最终落库。
协议对齐主链路
LoginRequestHandler- 登录后当前有对时和费率主动推送逻辑。
HeartbeatRequestHandler- 心跳包处理与最后通信时间刷新。
BillingTemplateValidateRequestHandler- 当前实现与协议偏差最大。
BillingTemplateRequestHandler- 负责
0x09 -> 0x0A。
- 负责
TimeCheckSettingResponseHandler- 用于记录
0x55对时应答。
- 用于记录
风险清单
- 现网桩程序可能已适配当前“非标准但可用”的平台行为,协议纠偏前需确认兼容性。
- 离线判定放宽后,真实离线的发现速度会变慢,需要平衡运维体验。
- 订单异常处理若改为延迟确认,需防止漏处理真正断电或断网导致的异常订单。
- 双实现收敛前,所有改动应明确打在老 Handler 链路上,避免误改新 Strategy 无法生效。
进度记录模板
### 进度记录
- 任务ID: YKC-001
- 优先级: P0
- 状态: todo
- 负责人:
- 开始时间:
- 完成时间:
- 目标: 调整 Netty 空闲断链策略,避免 30 秒无上行直接断链
- 修改文件:
- /Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServerChannelInitializer.java
- /Users/guoqiusi/Workspace/jsowell-charger-web/jsowell-netty/src/main/java/com/jsowell/netty/server/yunkuaichong/NettyServerHandler.java
- 验收结果:
- 备注/风险:
当前建议
- 先以第一批任务为本周主线,尽快止住凌晨离线误判。
- 第二批在止血完成后推进,避免协议纠偏与连接策略变更叠加,增加联调复杂度。
- 第三批收敛放在前两批稳定后执行。