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

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

  •  
  •   shadowfish0 · 4 天前 · 639 次点击

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

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

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

    一般头尾处理时间很少,那么就是网络数据转发太慢了,可能是网络延时太高
    shadowfish0
        3
    shadowfish0   4 天前
    @xuanbg 这个有办法优化吗,服务器是阿里云的学生机
    aqqwiyth
        4
    aqqwiyth   4 天前
    ping 一下看看延迟是多少 是不是有 100ms+
    关于   ·   帮助文档   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   1735 人在线   最高记录 5497   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 17ms · UTC 16:12 · PVG 00:12 · LAX 09:12 · JFK 12:12
    ♥ Do have faith in what you're doing.