You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

157 lines
15 KiB
Markdown

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

# 加餐四页面性能工具如何使用Performance
你好,我是李兵。
在分析页面性能时如果说Audits是道开胃菜那么Performance才是正餐之所这样说主要是因为Performance可以记录站点在运行过程中的性能数据有了这些性能数据我们就可以回放整个页面的执行过程这样就方便我们来定位和诊断每个时间段内页面的运行情况从而有效帮助我们找出页面的性能瓶颈。
不同于AuditsPerofrmance不会给出性能得分也不会给出优化建议它只是单纯地采集性能数据并将采集到的数据按照时间线的方式来展现我们要做的就是依据原始数据来分析Web应用的性能问题。
那么本节我们就继续深入聊聊如何使用Performance。通常使用Performance需要分三步走
1. 第一步是配置Performance
2. 第二步是生成报告页;
3. 第三步就是人工分析报告页,并找出页面的性能瓶颈。
接下来我会根据上面这三个步骤带你熟悉Performace并让你了解如何使用Performance来分析页面性能数据。
## 配置Performance
我们在Chrome中任意打开一个站点再打开Chrome开发者工具然后选择Performance标签最终效果如下图所示
![](https://static001.geekbang.org/resource/image/03/1c/036585de056964e025b9ed2ecd2bde1c.png)
Performance配置页
上图就是Performance的配置页观察图中区域1我们可以设置该区域中的“Network”来限制网络加载速度设置“CPU”来限制CPU的运算速度。通过设置我们就可以在Chrome浏览器上来模拟手机等性能不高的设备了。在这里我将CPU的运算能力降低到了**1/6**,将网络的加载速度设置为“**快的3G(Fast 3G)**”用来模拟3G的网络状态。
不同于Audits只能监控加载阶段的性能数据Performance还可以监控交互阶段的性能数据不过Performance是分别录制这两个阶段的你可以查看上图区域2和区域3我们可以看到这里有两个按钮上面那个黑色按钮是用来记录交互阶段性能数据的下面那个带箭头的圆圈形按钮用来记录加载阶段的性能数据。
另外你还要注意一点,这两种录制方式稍微有点不同:
* 当你**录制加载**阶段的性能数据时Performance会重新刷新页面并等到页面完全渲染出来后Performance就会自动停止录制。
* 如果你是**录制交互阶段**的性能时,那么需要手动停止录制过程。
## 认识报告页
无论采用哪种方式录制,最终所生成的报告页都是一样的,如下图所示:
![](https://static001.geekbang.org/resource/image/89/e3/89164eac8a512e7a677e6e7bc88068e3.png)
Performance的报告页
观察上图的报告页,我们可以将它分为三个主要的部分,分别为**概览面板、性能指标面板和详情面板**。
要熟练掌握这三个面板我们需要先明白时间线的概念这是因为概览面板和性能指标面板都依赖于时间线。我们知道Performance按照时间的顺序来记录每个时间节点的性能数据然后再按照时间顺序来展示这些性能数据那么展示的时候就必然要引入时间线了。比如上图中我们录制了10000毫秒那么它的时间线长度也就是10000毫秒体现在上图中就是概览面板最上面那条线。
#### 1\. 概览面板
好了,引入了时间线,**Performance就会将几个关键指标诸如页面帧速(FPS)、CPU资源消耗、网络请求流量、V8内存使用量(堆内存)等,按照时间顺序做成图表的形式展现出来,这就是概览面板**,你可以参看上图。
有了概览面板,我们就能一览几个关键的历史数据指标,进而能快速定位到可能存在问题的时间节点。那么如何定位可能存在问题的时间节点呢?
* 如果FPS图表上出现了红色块那么就表示红色块附近渲染出一帧所需时间过久帧的渲染时间过久就有可能导致页面卡顿。
* 如果CPU图形占用面积太大表示CPU使用率就越高那么就有可能因为某个JavaScript占用太多的主线程时间从而影响其他任务的执行。
* 如果V8的内存使用量一直在增加就有可能是某种原因导致了内存泄漏。
除了以上指标以外概览面板还展示加载过程中的几个关键时间节点如FP、LCP、DOMContentLoaded、Onload等事件产生的时间点。这些关键时间点体现在了几条不同颜色的竖线上。
#### 2\. 性能面板
通常,我们通过概览面板来定位到可能存在问题的时间节点,接下来需要更进一步的数据,来分析导致该问题的原因,那么应该怎么分析呢?
这就需要引入**性能面板**了,在性能面板中,记录了非常多的性能指标项,比如**Main**指标记录渲染主线程的任务执行过程,**Compositor指标**记录了合成线程的任务执行过程,**GPU指标**记录了GPU进程主线程的任务执行过程。有了这些详细的性能数据就可以帮助我们轻松地定位到页面的性能问题。
简而言之,**我们通过概览面板来定位问题的时间节点,然后再使用性能面板分析该时间节点内的性能数据**。具体地讲比如概览面板中的FPS图表中出现了红色块那么我们点击该红色块性能面板就定位到该红色块的时间节点内了你可以参考下图
![](https://static001.geekbang.org/resource/image/8f/d5/8f029c84fb7606360a83c4a1f01627d5.png)
选择时间线上的一段
观察上图我们发现性能面板的最上方也有一段时间线比如上面这个时间线所展示的是从360毫秒到480毫秒这段时间就是我们所定位到的时间节点下面所展示的Network、Main等都是该时间节点内的详细数据。
如果你想要查看事件范围更广的性能指标你只需要将鼠标放到时间线上滚动鼠标滚轮就可以就行缩放了。如果放大之后要查看的内容如果超出了屏幕那么你可以点击鼠标左键来拖动时间线直到找到需要查看的内容你也可以通过键盘上的“WASD”四个键来进行缩放和位置的移动。
#### 3\. 解读性能面板的各项指标
好了,现在我们了解性能面板,它主要用来展现**特定时间段内的多种性能指标数据**。那么要分析这些指标数据,我们就要明白这些指标数据的含义,不过要弄明白它们却并非易事,因为要很好地理解它们,**你需要掌握渲染流水线、浏览器进程架构、导航流程等知识点。**
因此在介绍性能指标之前,我们还需要岔开一下,回顾下这些前置的知识点。
因为浏览器的渲染机制过于复杂所以渲染模块在执行渲染的过程中会被划分为很多子阶段输入的HTML数据经过这些子阶段最后输出屏幕上的像素我们把这样的一个处理流程叫做**渲染流水线**。一条完整的渲染流水线包括了解析HTML文件生成DOM、解析CSS生成CSSOM、执行JavaScript、样式计算、构造布局树、准备绘制列表、光栅化、合成、显示等一系列操作。
渲染流水线主要是在渲染进程中执行的在执行渲染流水线的过程中渲染进程又需要网络进程、浏览器进程、GPU等进程配合才能完成如此复杂的任务。另外在渲染进程内部又有很多线程来相互配合。具体的工作方式你可以参考下图
![](https://static001.geekbang.org/resource/image/a4/09/a40850fbdfbfa4f95e1416b86bb24a09.png)
渲染流水线
关于渲染流水线和浏览器进程架构的详细内容我在前面的章节中也做了很多介绍,特别是《[05 | 渲染流程HTML、CSS和JavaScript是如何变成页面的](https://time.geekbang.org/column/article/118205)》和《[06渲染流程HTML、CSS和JavaScript是如何变成页面的](https://time.geekbang.org/column/article/118826)》这两节,你可以去回顾下相关章节的课程内容。
好了,我们简要回顾了渲染流水线和浏览器的进程架构,那么现在回归正题,来分析下性能面板各个指标项的具体含义。你可以参考下图:
![图片: https://uploader.shimo.im/f/hJhJWqCnFLg92XnR.png](https://static001.geekbang.org/resource/image/8b/3f/8bb592424abcef144aea6cd663d3593f.png)
性能面板
观看上图的左边我们可以看到它是由很多性能指标项组成的比如Network、Frames、Main等下面我们就来一一分析这些性能指标项的含义。
我们先看最为重要的**Main指标**它记录了渲染进程的主线程的任务执行记录在Perofrmace录制期间在渲染主线程上执行的所有记录都可以通过Main指标来查看你可以通过点击Main来展开主进程的任务执行记录具体你可以观察下图
![](https://static001.geekbang.org/resource/image/b4/03/b488c30b769f5289cd165c6844ebe803.png)
Main指标
观察上图一段段横条代表执行一个个任务长度越长花费的时间越多竖向代表该任务的执行记录。通过前面章节的学习我们知道主线程上跑了特别多的任务诸如渲染流水线的大部分流程JavaScript执行、V8的垃圾回收、定时器设置的回调任务等等因此Main指标的内容非常多而且非常重要所以我们在使用Perofrmance的时候大部分时间都是在分析Main指标。Main指标的内容特别多我会在下一节对它做详细分析。
通过渲染流水线,我们知道了渲染主线程在生成层树(LayerTree)之后,然后根据层树生成每一层的绘制列表,我们把这个过程称为**绘制(Paint)**。在绘制阶段结束之后,渲染主线程会将这些绘列表制**提交(commit)**给合成线程并由合成线程合成出来漂亮的页面。因此监控合成线程的任务执行记录也相对比较重要所以Chrome又在性能面板中引入了**Compositor指标**,也就是合成线程的任务执行记录。
在合成线程执行任务的过程中还需要GPU进程的配合来生成位图我们把这个GPU生成位图的过程称为**光栅化**。如果合成线程直接和GPU进程进行通信那么势必会阻塞后面的合成任务因此合成线程又维护了一个**光栅化线程池(Raster)**用来让GPU执行光栅化的任务。因为光栅化线程池和GPU进程中的任务执行也会影响到页面的性能所以性能面板也添加了这两个指标分别是**Raster指标**和**GPU指标**。因为Raster是线程池所以如果你点开Raster项可以看到它维护了多个线程。
渲染进程中除了有主线程、合成线程、光栅化线程池之外还维护了一个IO线程具体细节你可以参考《[15 | 消息队列和事件循环:页面是怎么“活”起来的?](https://time.geekbang.org/column/article/132931)》这篇文章。该IO线程主要用来接收用户输入事件、网络事件、设备相关等事件如果事件需要渲染主线程来处理那么IO线程还会将这些事件转发给渲染主线程。在性能面板上**Chrome\_ChildIOThread指标**对应的就是IO线程的任务记录。
好了以上介绍的都是渲染进程和GPU进程的任务记录除此之外性能面板还添加了其他一些比较重要的性能指标。
第一个是**Network指标**,网络记录展示了页面中的每个网络请求所消耗的时长,并以瀑布流的形式展现。这块内容和网络面板的瀑布流类似,之所以放在性能面板中是为了方便我们和其他指标对照着分析。
第二个是**Timings指标**用来记录一些关键的时间节点在何时产生的数据信息关于这些关键时间点的信息我们在上一节也介绍过了诸如FP、FCP、LCP等。
第三个是**Frames指标**,也就是浏览器生成每帧的记录,我们知道页面所展现出来的画面都是由渲染进程一帧一帧渲染出来的,帧记录就是用来记录渲染进程生成所有帧信息,包括了渲染出每帧的时长、每帧的图层构造等信息,你可以点击对应的帧,然后在详细信息面板里面查看具体信息。
第四个是**Interactions指标**,用来记录用户交互操作,比如点击鼠标、输入文字等交互信息。
#### 4\. 详情面板
通过性能面板的分析,我们知道了性能面板记录了多种指标的数据信息,并且以图形的形式展现在性能面板上。
具体地讲比如主线程上执行了解析HTML(ParserHTML)的任务,对应于性能面板就是一个长条和多个竖条组成图形。通过上面的图形我们只能得到一个大致的信息,如果想要查看这些记录的详细信息,就需要引入**详情面板**了。
你可以通过在性能面板中选中性能指标中的任何历史数据然后选中记录的细节信息就会展现在详情面板中了。比如我点击了Main指标中的ParserHTML这个过程下图就是详情面板展现该过程的详细信息。
![](https://static001.geekbang.org/resource/image/61/94/6148b6e934c8cf21319b9cc5bb3c5094.png)
详细信息
由于详情面板所涉及的内容很多而且每种指标的详细内容都有所不同所以本节我就不展开来讲了。另外你可以去Google的官方网站查看Performance的一些[基础使用信息](https://developers.google.com/web/tools/chrome-devtools/evaluate-performance/timeline-tool?hl=zh-CN)。
## 总结
好了,本节内容就介绍到这里,下面我来总结下本文的主要内容:
本节我们首先介绍了如何去配置Performance并生成报告页然后我们将焦点放在了如何解读报告页上。
之后我们介绍了报告页面主要分为三个部分,概览面板、性能面板和详情面板。
我们可以通过概览面板来定位问题的时间节点,然后再使用性能面板分析该时间节点内的性能数据。不过在分析数据时,我们需要弄明白性能面板内各项数据指标的含义,要了解这些,需要了解浏览器渲染流水线、浏览器的进程架构等知识点,因此结合这些知识点,我们接下来分析了性能面板的各项指标的含义。
其中最为重要的是Main指标它记录了渲染主线程上的任务执行情况不过这块细节内容会非常多所以我们会在下一节来介绍。
最后我们还介绍了每个指标项的内容都有详细数据,这些详细数据是通过详情面板来展现,你只需要通过性能面板点击相应的数据,就能通过详情面板来查看详细数据了。不过详情面板所涉及的数据也是非常多的,所以本文也就没对详情面板做过深的介绍了。
我把Performance比喻成一张网它能把我们在前面章节中很多知识点都网罗起来并应用到实践中。
## 思考题
那么今天留给你的任务是多找几个站点使用Performance来录制加载过程和交互过程并熟悉报告页面中的各项性能指标如果有遇到不明白的问题欢迎在留言区留言与我交流。
感谢阅读,如果你觉得这篇文章对你有帮助的话,也欢迎把它分享给更多的朋友。