网站首页 > 知识剖析 正文
业务背景
在存储大量数据,获取列表的业务场景下,我们采用了Mongodb的存储方式,其中标注时间业务的字段,均采用了String数据类型定义。
简述业务场景,A系统通过Http接口提交业务数据到系统B,请求参数存在唯一流水号标识;B系统存储业务数据到Mongodb中,异步去处理、组装数据提交到C系统(银行系统),系统C处理完数据以后,将会通过异步回调的形式通知系统B;系统B通过对应关系找到A系统的唯一流水号,进一步的异步回调给系统A。
发现问题
业务反馈,开发童鞋介入,发现系统A同一笔交易(业务单)编辑后,重新请求系统B,等到的回调竟然是业务单上一个版本的回调;且,系统A在接受回调的接口做了幂等操作,忽略了该次请求;导致的结果就是,业务编辑提交后许久,业务单一直处于处理中状态。
影响范围
发现部分业务单存在问题,大部分业务单是正常现象。排除了项目中统一时区的设定问题。
线下复现
复现的时间是上午,测试表示没有复现出来。很诡异!!!
排查问题
通过流水号观察日志,发现是B系统存储的在Mongodb中的时间字段,数据上存在问题,比如:创建时间是2022-05-01 14:24:10,然后系统存储的是2022-05-01 02:24:10。从而,系统B通过对创建时间倒排序后,获取业务单的最新一条记录时,获取的是业务单的第一笔请求流水。
服务器、mongodb节点
是否服务器时间问题,联系运维童鞋,查看了项目服务器各个节点当前时间,以及mongodb各个节点时间,结果都是正常的,问题又回归到了项目代码上。
排查代码
代码历史久远,最近一次迭代还是通过记录创建时间倒序查询。最后,发现问题。
demo复现
@Test
public void testTime() {
Date now = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
log.info("12小时制,时间:{}", sdf.format(now));
sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
log.info("24小时制,时间:{}", sdf.format(now));
}
[2022-05-01 14:35:34.106] [main] [INFO ] [com.xiu.boot.date.DateTest :26 ] 12小时制,时间:2022-05-01 02:35:34
[2022-05-01 14:35:34.107] [main] [INFO ] [com.xiu.boot.date.DateTest :28 ] 24小时制,时间:2022-05-01 14:35:34
紧急上线
开发修复bug,经过测试复现(修改了系统时间等操作),最后运维童鞋对系统进行平滑发布迭代修复上线。
事后复盘
1、业务场景发生概率下
业务单多次编辑,且在客户不撤销业务单,导致发现问题在上线迭代一段时间后。
2、历史代码,新需求场景
问题代码属于历史代码,新需求只是加了一个排序,导致对应开发童鞋坚持说不是代码的问题,影响了定位问题的方向。
3、问题定位方向错误
首先定位是项目时区设置,然后定位服务器时间不同步,最后定位代码。
4、系统A幂等处理结果优化
幂等处理的异常结果,不能忽略,应该直接报警处理。
猜你喜欢
- 2025-03-29 Django RESTFul接口如何对返回时间进行格式化?
- 2025-03-29 Java中时间格式化怎么实现?(java时间格式类型)
- 2025-03-29 Java 8 新特性:Date-Time API(java datetimeformatter)
- 2025-03-29 Python实现系统时间格式化常用方法
- 2025-03-29 为什么强烈推荐 Intl.format 格式化时间?
- 2025-03-29 jdk8Date LocalDateTime类学习笔记
- 2025-03-29 11个Excel日期和时间函数,易学易用,简单高效
- 2025-03-29 Java格式化日期,时间(三种方法,建议收藏
- 2025-03-29 Excel日期和时间函数的实用技巧:提升效率,精准掌控
- 2025-03-29 SpringBoot 日期格式化的两种方式
- 04-29php开发者composer使用看这一篇就够了
- 04-29引用和变量声明在不同语言中的实作
- 04-29PHP 没你想的那么差
- 04-29Ubuntu linux 上的 Nginx 和 Php 安装
- 04-29CentOS下通过yum搭建lnmp(单版本PHP)
- 04-29为什么 PHP8 是个高性能版本
- 04-29PHP8函数包含文件-PHP8知识详解
- 04-29使用无参数函数进行命令执行
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)