IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> JAVA知识体系之问题处理篇(二)——mysql时间毫秒四舍五入导致的生产问题 -> 正文阅读

[大数据]JAVA知识体系之问题处理篇(二)——mysql时间毫秒四舍五入导致的生产问题

1、问题发现

??近期,生产上订单系统出现了一笔问题交易:

  1. 一笔订单调用支付系统进行支付,支付系统返回处理中
  2. 订单系统异步查询支付结果,被告知订单不存在导致订单失败。
  3. 最终支付系统支付成功,订单系统启动异常处理机制撤销该支付。

2、背景描述

??调用链为业务系统->订单系统下单->支付系统支付。
??订单系统和支付系统都有幂等的要求,且幂等主键为上游请求系统、请求流水号、请求日期(截取自请求时间)。当查询时传入的请求三要素与下单/支付传入的请求三要素不同时则无法查询到订单。

3、问题追踪

  1. 经数据查询,发现订单系统数据库中记录的支付请求时间为2021/10/18 00:00:00 而支付系统数据库中记录的上游请求时间为2021/10/17 23:59:59。最终导致两个系统的请求日期不一致,订单系统无法查询到支付结果。
  2. 初步猜测在发起支付时下送的支付请求时间为业务系统请求时间,而插入表时新建了一个当前时间导致时间差;或者在插入表的时候重新取了数据库时间now();
  3. 经排查发现订单系统送给支付系统的时间与落库的支付请求时间为同一个字段。
  4. 猜测是mysql数据库搞的鬼。
  5. 查询资料得知mysql更新到5.6.4 之后 , 新增了factional seconds的特性 , 可以记录时间的毫秒值,超过500就会四舍五入,而系统中采用的mysql版本是5.7。
  6. 测试环境验证,问题复现。

4、问题解决

??在生成请求时间后对其进行格式化,去除毫秒级别数据,问题解决。

5、问题反思

??在查阅资料的时候看到一句话,作为反思:
在这里插入图片描述

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-10-22 11:00:15  更:2021-10-22 11:00:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 4:06:16-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码