使用Chrome DevTools的Timeline分析页面性能

原文地址:http://horve.github.io/2015/10/26/timeli...javascript

随着webpage能够承载的表现形式更加多样化,经过webpage来实现更多交互功能,构建web应用程序已经成为不少产品的首要选择。这种方式拥有很是明显的优点:跨平台、开发便捷、便于部署和维护等等,但随着功能的不断积累,web应用程序也会变得愈来愈复杂。可是,咱们仍然想要在webpage支持丰富的呈现形式的同时,让页面效果可以达到>=60fps(帧)/s的刷新频率以免出现卡顿,就须要咱们使用一些比较直观的方式来分析衡量页面的性能问题,为性能优化方案提供依据。html

为何是60fps?
咱们的目标是保证页面要有高于每秒60fps(帧)的刷新频率,这和目前大多数显示器的刷新率相吻合(60Hz)。若是网页动画可以作到每秒60帧,就会跟显示器同步刷新,达到最佳的视觉效果。这意味着,一秒以内进行60次从新渲染,每次从新渲染的时间不能超过16.66毫秒。java

需求大致明确,就是要找到页面执行过程当中的性能瓶颈。而Chrome DevTools的Timeline则正是用来记录和分析应用在运行时全部的活动状况,它是用来排查应用性能瓶颈的最佳工具。git

下图是Timeline面板的预览效果:github

Timeline预览效果图

Tips:为了不浏览器插件对分析过程产生影响,建议在隐身模式下进行分析。web

Timeline工具栏介绍

Timeline工具会详细检测出在Web应用加载的过程当中时间花费状况的概览,包括下载资源、处理DOM事件、页面布局渲染、向屏幕绘制元素等。你能够经过分析Timeline获得的事件、框架和实时的内存用量,找出应用的性能问题。chrome

Timeline的两种模式

在分析页面前,须要首先开启录制功能,记录页面的操做和渲染记录。如上图,左上角的灰色圆点就是录制按钮,点击后会变成红色,而后在页面上进行相关操做后再次按下变成灰色完成录制,这样就完成了一次对操做及加载渲染的记录过程,随后Timeline就会开始分析操做过程当中的各项性能参数。浏览器

Timeline同时提供了两种查看模式:“事件模式(Event Mode)”和“帧模式(Frame Mode)”。如上图箭头所示。性能优化

事件模式:显示从新渲染的各类事件花费的时间。
帧模式:显示每一帧的时间花费状况。网络

事件模式 (Event Mode)

若是咱们的一个页面执行效率不高,咱们必需要搞清楚致使页面性能低下的缘由,究竟是javascript执行出了问题,仍是页面渲染出了问题。要了解这里面的执行细节,咱们可使用“事件模式”来进行分析。首先咱们须要录制一些须要被分析的操做,录制结束后进入事件模式预览Timeline。下图是获得的事件模式的视图:

事件模式

在上图中,不一样的颜色表示不一样的事件。一种颜色的区块越长,说明在处理该事件的耗时就越长。单击某一区块,能够在下面的Summary概要中看到详细的事件处理过程及耗时分布。

事件类别

蓝色(Loading):网络通讯和HTML解析
黄色(Scripting):JavaScript执行
紫色(Rendering):样式计算和布局,即重排
绿色(Painting):重绘
灰色(other):其它事件花费的时间
白色(Idle):空闲时间

在显示的记录中,浏览器也会为在检测过程当中发现的一些可能致使性能问题的过程进行标注,在Mode View视图区域,可能会出现一些红色的区块段,这些红色的区块段代表,在对应的时间上执行的事件可能存在性能问题,而在对应的Main Thread视图区域,事件区块的右上角会出现红色的小三角,点击当前区块,在下面的Summary概要区域内会给出详细的警告内容以及脚本可能出现问题的行数,以下图,浏览器提示“强制同步布局可能会致使性能瓶颈”:

性能问题标注

此外,在关闭Event Mode后,还能够看到Record Detail视图,详细列出一次记录中各种事件的详细内容。

Record Detail视图

Record Detail视图区域的左侧是事件标题,右侧是对应的时间线。点击每一条时间标题能够看到更多信息,如事件发生在脚本的哪一行等。若是你只对某一个时间段内的某些操做感兴趣,能够经过移动时间轴的始末位置来选择要浏览的区域:

选取一部分记录

帧模式 (Frame Mode)

帧模式从页面渲染性能的角度提供了数据支撑,一个柱状“frame”表示渲染过程当中的一帧,也就是浏览器为了渲染单个内容块而必需要作的工做,包括:执行js,处理事件,修改DOM,更改样式和布局,绘制页面等。

如前文所述,咱们的目标是保证页面要有高于每秒60fps(帧)的刷新频率,这样就能保证页面有高流畅度的渲染。

帧模式视图

中在Frame视图中有两条贯穿该视图的横线,分别标识出60FPS和30FPS的基准,按照前面提到的16.66ms的计算方式,咱们能够理解为分别标识了16.6ms和33.3ms两个时间点。下面的一条是60FPS,低于这条线,能够达到每秒60帧;上面的一条是30FPS,低于这条线,能够达到每秒30次渲染。若是色柱都超过30FPS,这个网页就有性能问题了。

图中帧柱的高度表示了该帧的总耗时,帧柱中的颜色分别对应该帧中包含的不停类型的事件。每一帧柱的高度越低越好,上图是艺龙PC首页www.elong.com的帧渲染图,从图中能够看出,在进行某些帧的渲染时,帧的渲染频率低于30FPS/s,第二帧和第三帧就大幅低于30fps(帧柱高度高于30fps标准线),在实际浏览器渲染中就有可能出现卡顿。对相关的帧进行分析时,能够点击其中某一帧查看渲染详情,也能够选择某个区域的几个帧查看渲染详情。而要找出可能影响性能的缘由,点击当前问题帧,在Summary面板及Record Detail视图中的详细信息中进行逐条分析。

你可能注意到了在帧柱上存在灰色区域和空白区域,它们分别表明:
灰色区块:那些没有被DevTools感知到的活动
空白区块:显示刷新周期(display refresh cycles)中的空闲时间段

点击某一个帧柱还能够获得该帧的详细记录数据:

帧详情

Warning: 警告信息
ScreenShot: 当前选中帧的渲染截屏
Duration: 该记录及其子记录的总耗时
FPS: 当前帧的渲染频率
CPU Time: CPU耗时
Aggregated Time: 合计耗时分布

总结

发现问题是解决问题的第一步,chrome浏览器的TimeLine工具能够很好地辅助咱们分析页面的性能瓶颈,提供详细全面的分析数据,为咱们进行性能优化提供数据依据。固然,TimeLine中有用的功能还有不少,好比Memery Mode, Screen Shot等,使用技巧多种多样,在这里主要介绍了如何去记录一段渲染过程,如何去使用Event ModeFrame Mode去查看并分析获得性能指标,后续若是有新的体会和发现,还会再作记录~

TimeLine中的事件汇总

Loading事件

事件 描述
Parse HTML 浏览器执行HTML解析
Finish Loading 网络请求完毕事件
Receive Data 请求的响应数据到达事件,若是响应数据很大(拆包),可能会屡次触发该事件
Receive Response 响应头报文到达时触发
Send Request 发送网络请求时触发

Scripting事件

事件 描述
Animation Frame Fired 一个定义好的动画帧发生并开始回调处理时触发
Cancel Animation Frame 取消一个动画帧时触发
GC Event 垃圾回收时触发
DOMContentLoaded 当页面中的DOM内容加载并解析完毕时触发
Evaluate Script A script was evaluated.
Event js事件
Function Call 只有当浏览器进入到js引擎中时触发
Install Timer 建立计时器(调用setTimeout()和setInterval())时触发
Request Animation Frame A requestAnimationFrame() call scheduled a new frame
Remove Timer 当清除一个计时器时触发
Time 调用console.time()触发
Time End 调用console.timeEnd()触发
Timer Fired 定时器激活回调后触发
XHR Ready State Change 当一个异步请求为就绪状态后触发
XHR Load 当一个异步请求完成加载后触发

Rendering事件

事件 描述
Invalidate layout 当DOM更改致使页面布局失效时触发
Layout 页面布局计算执行时触发
Recalculate style Chrome从新计算元素样式时触发
Scroll 内嵌的视窗滚动时触发

Painting事件

事件 描述
Composite Layers Chrome的渲染引擎完成图片层合并时触发
Image Decode 一个图片资源完成解码后触发
Image Resize 一个图片被修改尺寸后触发
Paint 合并后的层被绘制到对应显示区域后触发

参考文档

https://developers.google.com/chrome-dev...

http://www.w3cfuns.com/article-1248-1.ht...

http://www.oschina.net/translate/perform...

相关文章
相关标签/搜索