我在拦截器 preHandle 里记录了调用开始时间,在 afterCompletion 里计算总调用时间,用的 System.nanoTime(),结果日志显示这里只花了 42ms,但是调试工具里显示的 Waiting(TTFB)有 176ms,太诡异了,摸不着头脑
1
CEBBCAT 2021-09-15 02:20:39 +08:00 via Android
嗯……那亲亲有没有过考虑网络延时、TCP 握手时间呢?
P.S. 42ms 有点长了呢,这边建议您检查一下慢 SQL 和圈复杂度呢 |
2
xuanbg 2021-09-15 04:22:17 +08:00
调用短本地的请求处理时间+网络转发时间(含网络延时)+服务端处理时间(42ms)+网络转发时间(含网络延时)+调用端处理请求结果时间=176ms
一般头尾处理时间很少,那么就是网络数据转发太慢了,可能是网络延时太高 |
3
shadowfish0 OP @xuanbg 这个有办法优化吗,服务器是阿里云的学生机
|
4
aqqwiyth 2021-09-15 21:08:30 +08:00
ping 一下看看延迟是多少 是不是有 100ms+
|