JAVA后端服务端与移动端客户端高精度时间同步思路

一、脑补

在Chrome--->Network----> Timing中可以查看一个请求在各个阶段所花费的时间。

Timing中各个字段的意思发:

**1、Queueing:**从增加到等待处理队列到实际开始处理的时间间隔------浏览器也有线程机制,所有的请求不能同时发送,也需要队列排队处理请求。

**2、Stalled:**浏览器从请求队列获取到要发出的请求到请求可以发出的等待时间(通常为代理协商以及等待可复用的TCP连接释放)

**3、DNS Lookup:**DNS执行查找的一个完整的往返时间(将域名解析为IP)。当本地DNS缓存没有的时候需要消耗这段时间,否则基本都为0;

4、Initial connection:建立TCP连接的时间(即DNS查询+Proxy时间+TCP握手时间等)

5、Request sent:请求第一个字节发出前到最后一个字节发出后的时间(即上传时间);

6、Waiting(Time To First Byte,TTFB):请求发出到收到响应的第一个字节所花费的时间;

7、Content Download:收到响应的第一个字节到接受完最后一个字节的时间(即下载时间);

二、客户端/服务端时间同步倒计时

javascript 复制代码
let now = new Date().getTime(); 

// 伪代码 -- 获取响应时间,相当于success里的new date().getTime();
let end = getResponseTime();

// 伪代码 -- 获取服务器响应时提供的服务器时间,success后从body里面获取的数据,由后端塞进去的;
var serverTime = getServerTime();  

// 获取TTFBTime,具体怎么获取去网上搜,这里不说了,说下去太多,本文只提供思路;
var TTFBtime = getTTFBTime();

// 得到当前服务器时间,该时间一般偏快于服务器时间0~10ms左右,具体原因从第一节"脑补"中就可以得知;
var currServerTime = serverTime + (end - now) - TTFBTime;
 

* 还可以考虑NTP时间同步,可以继续探索

三、扩展与思考---接口优化/请求时长优化

根据上面脑补后,咱们知道"发送请求完毕"到"开始接收请求"的时间就代表服务器处理业务的时间和和返回数据的网络延时时间。

那么,咱们做接口优化方面就可以根据这个点来作为依据,从而做到更精准的优化效果。

相关推荐
j7~5 分钟前
【C++】STL--string类--拆析解剖string类的实现以及string类的底层详解(2)
开发语言·c++·浅拷贝·深拷贝·string类的实现·string拷贝构造·string赋值重载
实在智能RPA9 分钟前
航空Agent落地效果评估指标:2026年企业级智能自动化价值度量体系拆解
java·网络·人工智能·ai·自动化
程序员二叉15 分钟前
【JUC】AQS底层深度拆解|独占/共享模式|队列原理全详解
java·开发语言·面试·juc
踏着七彩祥云的小丑16 分钟前
Go 学习第6天:结构体 + 切片 + range遍历
开发语言·学习·golang·go
读书札记202219 分钟前
Qt中windeployqt.exe工具的使用:解决使用CMake创建的项目点击exe文件后系统提示0xc000007b的问题
开发语言·qt
地铁潜行者20 分钟前
消息堆积后,为什么一扩容消费者,MySQL 先被打崩了?
java·后端
地铁潜行者23 分钟前
订单状态更新成功了,分账消息却没发出去:聊聊本地消息表的一致性坑
java·后端
亦暖筑序23 分钟前
Java 8老系统SQL Agent实战:AI生成候选SQL,安全引擎拦截后再执行
java·人工智能·sql
CodeStats25 分钟前
《源纹天书》卷一:归元初醒(第1-5章)
java
大囚长29 分钟前
大模型服务端如何命中缓存
java·人工智能·缓存·dubbo