谷歌chrome浏览器network中Stalled分析和优化

问题由来

最近项目上要求首页的加载速度,查看浏览器的network发现接口加载速度非常慢。

问题解决思路

SSL

网上有人因为图片加载,选择关闭SSL.就不存在问题,速度非常快
原因:查询相关资料使用ssl效率降低60%左右。
结果:SSL是一种安全协议(在此不做具体分析),不舍弃安全协议去优化性能

Network

Network中的瀑布流可直观查看到接口调用详细
本文主要从Network入手,并且逐步解决问题

分析过程

简单列出 chrome network的功能

1. Name:表示加载的文件名。
2. Method:表示请求的方式。
3. Status:表示状态码(200为请求成功,304表示从缓存读取)。
4. Type:表示文件的MIME Type的类型。
5. Initiator:表示发出这个文件请求的发出者。
6. Size:表示文件大小。
7. Time:表示每个请求的总时长。
8. Timeline:以图表的形式显示元素的请求和加载情况。

1.关闭从缓存加载,避免缓存导致的影响

取消勾选
谷歌chrome浏览器network中Stalled分析和优化-LMLPHP

2.从Network瀑布流中查看哪些接口的请求时间比较长

点击Time从大到小排序
两种图表表达情况
谷歌chrome浏览器network中Stalled分析和优化-LMLPHP
图一

谷歌chrome浏览器network中Stalled分析和优化-LMLPHP
图二

图一(前后端均需要优化)

后端:优化接口,优化sql语句,提升接口响应速度.但有时候确实因为数据量巨大,类似表格数据,后端查询完毕还需要进行处理,所以耗时长
前端:最简单的解决办法就是减少数据量,例如限制一个范围(时间、分页处理)

图二(前端优化)

先来看看Network上的详细信息
谷歌chrome浏览器network中Stalled分析和优化-LMLPHP
关注红框的两个值Stalled、Waiting
实际上就是等待了Stalled(1.47S才开始正式请求数据),数据请求到完成的时间实际上很短

那么到底什么是Stalled呢? 具体我们去查询资料分析分析

Stalled

又有问题了!! 明明我的网络很好,为什么会发生重传呢?

总结一下:stalled阶段时TCP连接的检测过程,如果检测成功就会继续使用该TCP连接发送数据,如果检测失败就会重新建立TCP连接。所以出现stalled阶段过长,往往是丢包所致,这也意味着网络或服务端有问题。

上面也说过,网络是没有问题的,同时也确认过服务端没有问题,那么总结的不就是有问题的吗? 我们在分析下一般情况下stalledstalled的原因有哪些呢?

也就是说根本问题是在于浏览器的底层上
浏览器对同一个主机域名的并发连接数有限制,因此如果当前的连接数已经超过上限,那么其余请求就会被阻塞,等待新的可用连接
我们还需注意的是脚本也会进行阻塞

浏览器对同一域名进行请求的最大并发连接数

问题的根本原因也找到了,那么解决方案也就应运而出了.
将数据展示的接口放在其他接口前面进行调用即可实现数据展示不被阻塞,页面就会第一时间显现出来,使得用户体验更好,项目优化完成.

如果错误,请指出!!!

06-17 03:06