为啥 spring 通过拦截器记录的接口处理时间和浏览器记录的 Waiting(TTFB)时间差距这么大

2021-09-15 01:34:58 +08:00
 shadowfish0

我在拦截器 preHandle 里记录了调用开始时间,在 afterCompletion 里计算总调用时间,用的 System.nanoTime(),结果日志显示这里只花了 42ms,但是调试工具里显示的 Waiting(TTFB)有 176ms,太诡异了,摸不着头脑

1222 次点击
所在节点    程序员
4 条回复
CEBBCAT
2021-09-15 02:20:39 +08:00
嗯……那亲亲有没有过考虑网络延时、TCP 握手时间呢?

P.S. 42ms 有点长了呢,这边建议您检查一下慢 SQL 和圈复杂度呢
xuanbg
2021-09-15 04:22:17 +08:00
调用短本地的请求处理时间+网络转发时间(含网络延时)+服务端处理时间(42ms)+网络转发时间(含网络延时)+调用端处理请求结果时间=176ms

一般头尾处理时间很少,那么就是网络数据转发太慢了,可能是网络延时太高
shadowfish0
2021-09-15 09:52:12 +08:00
@xuanbg 这个有办法优化吗,服务器是阿里云的学生机
aqqwiyth
2021-09-15 21:08:30 +08:00
ping 一下看看延迟是多少 是不是有 100ms+

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/801875

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX