为什么我们感觉打开网页很慢?

转自公众号文章:https://mp.weixin.qq.com/s/3VBQKWhX5DNUZad1CP-9DQ

我们经常遇到的问题

在我们的测试日常中,不免会遇到网页性能感知测试的工作,比如:测试访问某个网页耗时。针对此类测试,笔者经历过两种简单的方法:测试网页使用的后端接口响应耗时等同为网页耗时;使用秒表计算网页响应耗时。

测试网页响应耗时,我们需要知道触发网页请求时,直至网页刷新、响应,整个过程到底包含了些什么。

从大体来分,主要包含两部分耗时:后端接口请求响应耗时和前端页面资源加载耗时。而抛开前端页面资源加载时间,单纯将后端接口响应耗时等同为网页响应耗时是不准确的;而不清除浏览器本身资源配置和消耗,简单使用秒表计算网页响应耗时,结果是粗泛不准确的。

那么,我们应该怎么测试网页响应耗时呢?当我们感觉打开网页很慢的时候,到底是因为什么原因呢?

image.gif

认识Performance面板

工欲善其事必先利其器,你知道测试网页应用,浏览器是必不可少的。但是,如何利用浏览器分析网页性能,你知道吗?

以Chrome为例,首先,让我们再来认识一下这个强大、丰富的工具——“开发者工具”。

使用Ctrl+Shift+I打开开发者工具,可见Elements、Source、Network、Performance等9大面板。我们分析网页性能时,主要使用的是Performance面板。

以百度搜索“51testing”为例,打开Chrome开发者工具,切换到Performance面板,点击record按钮,记录网页操作,记录结果如图2所示。

图1 Performance面板记录百度搜索操作结果

在分析网页性能之前,我们先认识下Performance面板的一些功能。如图2所示,Performance面板从上到下主要分为4个功能区:具体操作区,概览区,性能分析区,性能摘要区。

1. 具体操作区:包含录制,刷新页面分析,清除结果等一系列操作 ;

2. 概览区:高度概括随时间线的变动,包括FPS,CPU,NET,每个时间段执行的事件顺序,可以知道每个时间段(精确到毫秒)都做了什么。当鼠标放上去的时候,我们还可以大图的形式去查看我们每个时间段界面的渲染情况;

3. 性能分析区:从不同的角度分析框选区域 。

例如:Network可以直观的看到后台请求响应时长,Frames可以直观看到每帧加载耗时,Main 是Performance工具中比较重要的部分,记录了渲染进程中主线程的执行记录,点击main可以看到某个任务执行的具体情况 ;

4. 性能摘要区:精确到毫秒级的分析,以及按调用层级,事件分类的整理。

图2 Performance面板功能区

Performance面板实践

了解了Performance面板之后,让我们来“康康”,如何结合Performance面板分析和解决我们遇到的问题。

1. 如何监测网页响应耗时?

结合Performance面板的概览区和性能分析区的Frames视图,拖动观察区域,可以清楚地获知每帧图片加载耗时。以图2为例,可以看出从输入关键字“51testing”到显示搜索结果,整个过程网页耗时1332ms。

使用Performance面板,可以更加精确计算网页响应耗时。此外,通过FPS图表,可以看到帧率波动(如下图箭头所示)。通常,绿色条越高,FPS越高,只要在FPS上方看到了红色条,就表示帧率下降的很低,当动画以60FPS运行时,用户会感觉很流畅。

2. 如何分析网页响应过程中各个阶段耗时?

点击性能分析区的main功能,在性能摘要区可以看到每个阶段,如Loading(加载)、Scripting (js计算时间)、Rendering (渲染时间)等耗时。

还可以看到每个事件耗时(一段横条代表执行一个事件,长度越长,花费的时间越多),和该事件的调用栈及其调用栈耗时(竖向代表调用栈),从下图可知,搜下“51testing”到响应出结果的过程中,Scripting耗时占比最大。且通过main功能,可以看到如果在这些横条中右上角是红色的就表示在该段代码执行过程中可能存在性能问题,如下图箭头所示部分。

3. 如何分析网页响应中各个接口调用耗时?

点击性能分析区的network功能,可以看到,在网页响应过程中,每个请求的网络耗时和资源加载耗时。

!片](https://upload-images.jianshu.io/upload_images/6993402-b8df1cb1a4367c73?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

4. 如何识别网页内存溢出?

在开始Performance录制时,勾选具体操作区的“Memory”选项,Performance面板会记录网页加载过程中,不同的时间段,不同事件(如下图中所示的JS Heap,Documents等)的执行情况的内存消耗。通过观察概览区的内存随时间线变化,如果内存呈不断增长的趋势,那么,就可能存在内存溢出的情况。

图片
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,869评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,716评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,223评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,047评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,089评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,839评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,516评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,410评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,920评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,052评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,179评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,868评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,522评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,070评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,186评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,487评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,162评论 2 356

推荐阅读更多精彩内容