解决实际项目中stalled时间过久的问题

这篇具有很好参考价值的文章主要介绍了解决实际项目中stalled时间过久的问题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

背景

在公司参与了一个做度量统计的项目,该项目的特点是页面上的表格、卡片、图标非常多。项目经常出现一种情况:页面加载速度较慢,开始怀疑是由于计算量较大,后端接口相应速度较慢。优化了一版后端接口后(加缓存、优化SQL),发现有时接口的相应速度还是很慢,有的接口能达到3秒多,严重影响了用户体验。

问题排查

页面加载速度太慢,严重影响了用户体验,因此必须要解决这个问题。

开始的时候怀疑是后端接口问题,因此针对一些计算量确实很大的接口,对热点数据加了缓存。理论上来说,加了缓存后接口速度应该在100ms以内就可以返回,但是实际在页面上查看接口返回时间时,发现接口的返回时间有时还是会到3秒左右,这种情况就存在问题了。

针对单一接口,我使用postman发起调用,发现无法复现该问题,只有在前端页面上请求才会存在返回时间超过3秒的情况。因此,我们开始使用Chrome浏览器提供的工具查看这些耗时较多的接口(由于公司数据不可外泄,因此在博客里面我就直接使用公开的报表页面进行排查演示)。

解决实际项目中stalled时间过久的问题
从该页面中选取了一个接口进行测试,点击Chrome浏览器的调试按钮,查看网络面板中的时间数据,整个接口的耗时如上图所示。

简单解释一下:该接口整体的响应时间为281.47ms,其中Stalled时间占用了169.84ms的时间,获取后端接口数据的时间为111.63ms。其中,111.63ms可以理解为后端接口的真实响应时间,但是stalled的这段时间是干什么的呢?这一阶段的耗时比后端接口返回数据的时间还要长。

对Chrome发起的网络请求进行抓包,具体操作如下:

解决实际项目中stalled时间过久的问题

  1. 进入chrome://net-export/网页点击开始调试
  2. 重新请求该报表页面
  3. 停止抓包,保存日志文件
  4. 进入https://netlog-viewer.appspot.com/#import网页,导入抓包日志,对抓包日志进行可视化分析,结果如下图所示
    解决实际项目中stalled时间过久的问题
    点击最上侧的搜索框,可以按照接口URL进行搜索,搜索排查后发现接口是在
    HTTP_STREAM_REQUEST_BOUND_TO_JOB阶段耗时过多,再进一步查看,发现是接口在等待复用套接字。

到这里,我们就知道为什么前端页面上的接口相应时间过长了,主要时间都耗费在等待复用套接字上了,那为什么会在这个地方进行等待呢,是因为HTTP1.1限制了在Chrome浏览器下对同一个域名的并发请求最大是6,当超过6个时,就得排队等待前面的请求数据返回释放套接字后才能进行请求。

问题解决

查明了问题,那如何解决这个问题呢?
两个办法:一个是由于HTTP1.1是对单个域名限制了并发请求数,那我们可以同时对多个域名进行请求来避免阻塞;另一个是升级HTTP协议,将HTTP协议升级到HTTP2.0,HTTP2.0由于多路复用的特性,不再限制并发请求数(需注意对后端系统的负载影响,同时并发请求会对后端系统造成更大的负载,还需注意客户端对HTTP2.0协议的兼容性,如果不兼容的话,即使开启了HTTP2.0,也会退化到HTTP1.1的)。

综合多种考虑,结合公司里关于HTTP2.0的故障反馈,确认对我们的系统无影响后,我们决定升级HTTP协议来解决该问题,先在测试环境开启,测试几天后,在线上环境灰度开启,最终全部开启。

注意,HTTP2.0协议强依赖于HTTPS协议,需确保服务首先支持HTTPS协议!文章来源地址https://www.toymoban.com/news/detail-421053.html

到了这里,关于解决实际项目中stalled时间过久的问题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • RabbitMQ常见问题以及实际问题解决

    ** ** 消息可靠性问题: 消息从生产者发送到Exchange,再到queue,再到消费者,有哪些导致消息丢失的可能性? 发送时丢失: - 生产者发送的消息为送达exchange - 消息到达exchange后未到达queue MQ宕机,queue将消息丢失 consumer接收到消息后未消费就宕机 ①生产者消息确认 RabbitMQ提供

    2024年02月16日
    浏览(49)
  • vue项目为例解决element ui 时间选择器 picker使用样式穿透不起作用问题

    今天在开发中 需要修改时间选择器弹出的这个组件的样式 但这个东西比较坑爹 首先 不能影响其他组件 就是其他组件用了时间选择器 不能受到我们写的样式的影响 那么 就只好穿透了 但你会发现 这东西是作用与body下的 就很坑 穿透我试了挺久的 不起作用 但官方文档有提供

    2024年02月05日
    浏览(40)
  • 人工智能与创新:如何解决实际问题

    人工智能(Artificial Intelligence, AI)是一种计算机科学的分支,旨在让计算机具有人类般的智能。人工智能的目标是让计算机能够理解自然语言、识别图像、解决问题、学习和自主决策等。人工智能技术的应用范围广泛,包括机器学习、深度学习、自然语言处理、计算机视觉、语

    2024年02月19日
    浏览(46)
  • kafka消费者详解,根据实际生产解决问题

    1.首先kafka每创建一个消费者就是一个消费者组,必须指定groupip 2.两个消费者组之间不相互影响,消费同一个主题的同一个分区,两个消费者组不相互影响,各自记录自己的offset 3.在开发中如果没有指定每个消费者去消费特定的分区,那么kafka默认是按照roundRobin轮询的方式分

    2024年02月10日
    浏览(49)
  • HBase实际应用中常见的问题 解决方案

    HBase 是一个分布式的、面向列的开源数据库,通常用于处理大规模数据。在实际应用中,可能会遇到一些常见问题,以下是一些常见问题及其解决方案: 性能问题 : 问题 :HBase 性能下降,读写延迟增加。 解决方案 :可以通过增加 Region Server、优化 HDFS、调整 HBase 配置参数

    2024年01月19日
    浏览(43)
  • 【docker系列】docker解决的实际问题及应用场景

    笔者打算写一个完整系列的docker知识总结,本文是第一篇,主要介绍docker是什么?主要的应用场景是什么?解决了哪些问题?和虚拟机有什么区别? Docker 是一个开源的容器引擎,它轻巧,且易移植,“build once, configure once and run anywhere”。使用go语言开发,并遵从apache2.0协议

    2023年04月08日
    浏览(44)
  • vue项目引用海康视频插件(web1.5),el-date-picker下拉选择时间面板会被遮盖问题解决。

    一、海康插件浮窗的层级,会把项目中时间控件中的时间选择面板挡住,导致时间面板显示不全,无法选择时间。如图所示: 二、解决办法:调用API中的JS_ JS_CuttingPartWindow(iLeft, iTop, iWidth, iHeight )方法, 三、效果图 四、API接口文档 大致意思就是当点击时间控件出现时间选择

    2024年02月11日
    浏览(41)
  • 数据结构与算法学习(day4)——解决实际问题

    在本章的学习此前,需要复习前三章的内容,每个算法都动手敲一遍解题。宁愿学慢一点,也要对每个算法掌握基本的理解! 前面我们学习了简化版桶排序、冒泡排序和快速排序三种算法,今天我们来实践一下前面的三种算法。 本章的学习目标: (1)回顾三个算法的基本原

    2024年02月09日
    浏览(57)
  • 【网络安全】理解报文加密、数字签名能解决的实际问题

    工作中重新接触了 【公钥、私钥、签名】的概念。抽空重新看了《计算机网络》和国外的小黑书,把这块基础知识再收敛一下。基于小黑书的叙事结构,把网络安全解决的实际问题拆解成: 防止报文泄露 防止报文被篡改 实体鉴别 端点鉴别 防止重放攻击 1. 防止报文泄露 —

    2024年02月11日
    浏览(45)
  • .Net 6 SignalR 实际业务开发中遇到的问题及解决办法

    1.websocket即时通讯协议 2.Server-Sent Events(SSE)服务器事件 3.longpolling 长轮询。 如果客户端开启协商,会按顺序选择可兼容的协议。(默认开启协议协商) 如果客户端禁用协商,只能websocket协议。 客户端未禁用协商 1.客户端向服务器发http请求,询问服务器支持什么协议。 服务

    2024年02月10日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包