V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
shadowfish0
V2EX  ›  程序员

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

  •  
  •   shadowfish0 · 2021-09-15 01:34:58 +08:00 · 1199 次点击
    这是一个创建于 926 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    4 条回复    2021-09-15 21:08:30 +08:00
    CEBBCAT
        1
    CEBBCAT  
       2021-09-15 02:20:39 +08:00 via Android
    嗯……那亲亲有没有过考虑网络延时、TCP 握手时间呢?

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

    一般头尾处理时间很少,那么就是网络数据转发太慢了,可能是网络延时太高
    shadowfish0
        3
    shadowfish0  
    OP
       2021-09-15 09:52:12 +08:00
    @xuanbg 这个有办法优化吗,服务器是阿里云的学生机
    aqqwiyth
        4
    aqqwiyth  
       2021-09-15 21:08:30 +08:00
    ping 一下看看延迟是多少 是不是有 100ms+
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   3571 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 10:31 · PVG 18:31 · LAX 03:31 · JFK 06:31
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.