百度大神是如何在7 天内打造一个前端性能监控系统的?

事情是这样的:

百度的张涛同学在w3ctech的走进名企-百度前端FEX专场上曾“夸下海口”说听完讲座后七天就可以打造自己的前端性能监控系统,本着“话既然说出去了,那就不能食言”的原则,写了下面这篇文,极客君看完,只有八个字:干货满满,十足有料!

现在,我们就一起来膜拜膜拜,张大神是如何在7天内打造一个前端性能监控系统的?!


                                           这是张大神干货分享开始的分割线

开始行动

本文中的性能主要指web页面加载性能,对性能还不了解?不用担心,接下来的“每一天”跟我一起进入前端性能的世界。

Day 1:为什么要监控性能?

“If you cannot measure it, youcannot improve it” ———— William Thomson

这是一个最基本的问题,为什么要关注和监控前端性能?对于公司来说,性能在一定程度上与利益直接相关。国外有很多这方面的调研数据:

百度大神是如何在7 天内打造一个前端性能监控系统的?_第1张图片

数据来源:http://www.slideshare.net/bitcurrent/impact-of-web-latency-on-conversion-rateshttp://stevesouders.com/docs/jsdayit-20110511.pptx

为什么性能会影响公司的收益呢?根本原因还是在于性能影响了用户体验。加载的延迟、操作的卡顿等都会影响用户的使用体验。尤其是移动端,用户对页面响应延迟和连接中断的容忍度很低。想象一下你拿着手机打开一个网页想看到某个信息却加载半天的心情,你很可能选择直接离开换一个网页。谷歌也将页面加载速度作为SEO的一个权重,页面加载速度对用户体验和SEO的影响的调研有很多。

尽管性能很重要,开发迭代过程中难免会有所忽视,性能会伴随产品的迭代而有所衰减。特别在移动端,网络一直是一个很大的瓶颈,而页面却越来越大,功能越来越复杂。并没有简单的几条黄金规则就可以搞定性能优化工作,我们需要一套性能监控系统持续监控、评估、预警页面性能状况、发现瓶颈,指导优化工作的进行。


Day2:有什么可用的工具?

工欲善其事必先利其器

页面性能的评估与监控有很多成熟优秀的工具,合理利用已有工具能达到事半功倍的效果。下面简单介绍几个常用的工具:

PageSpeed

Page Speed是谷歌开发的分析和优化网页的工具,可以作为浏览器插件使用。工具基于一系列优化规则对网站进行检测,对于未通过的规则会给出详细的建议。与此类似的工具还有Yslow等,推荐使用gtmetrix网站同时查看多个分析工具的结果,如下图所示:

百度大神是如何在7 天内打造一个前端性能监控系统的?_第2张图片

WebPagetest

WebPageTest是一款非常优秀的网页前端性能测试工具,已开源。可以使用在线版,也可以自己搭建。国内也有利用WebPagetest搭建的性能测试平台,推荐使用阿里测(以下示例使用阿里测进行测试)。

使用WebPagetest,你可以详细掌握网站加载过程中的瀑布流、性能得分、元素分布、视图分析等数据。其中比较直观的视图分析功能可以直接看到页面加载各个阶段的截屏:

百度大神是如何在7 天内打造一个前端性能监控系统的?_第3张图片

上图直观地展现了浏览类网站两个重要的时间点:白屏时间和首屏时间,即用户多久能在页面中看到内容,以及多久首屏渲染完成(包含图片等元素加载完成)。这两个时间点直接决定了用户需要等待多久才能看到自己想看到的信息。谷歌优化建议中也提到减少非首屏使用的css及JS,尽快让首屏呈现。

PhantomJS

PhantomJS轻松地将监控带入了自动化的行列。Phantom JS是一个服务器端的JavaScript API的WebKit,基于它可以轻松实现web自动化测试。PhantomJS需要一定编程工作,但也更灵活。官方文档中已经有一个完整的获取网页加载har文件的示例,具体说明可以查看此文档,国内也有不少关于此工具的介绍。另外新浪@貘吃馍香开发的类似工具berserkJS也挺不错,还贴心的提供了首屏统计的功能,具体文章可以查看此处。


Day3: 开始线上真实用户性能监控

取其所长,避其所短

到此肯定有同学问,既然有这么多优秀的工具,为什么要监控线上用户真实访问性能呢?

我们发现,工具模拟测试会在一定程度上与真实情况偏离,有时无法反映性能的波动情况。另外除了白屏首屏之类的基础指标,产品线同样关注产品相关的指标,例如广告可见、搜索可用、签到可用等,这些功能直接与页面JS加载相关,通过工具较难模拟。

为了持续监控不同网络环境下用户访问情况与页面各功能可用状况,我们选择在页面中植入JS来监控线上真实用户访问性能,同时利用已有的分析工具作为辅助,形成一套完整多元的数据监控体系,为产品线的评估与优化提供可靠的数据。

关于不同监控方式的简单对比可以查看下表:

百度大神是如何在7 天内打造一个前端性能监控系统的?_第4张图片

Day4:如何采集性能数据?

监控用户的痛点

线上监控哪些指标呢?如何更好地反映用户感知?

对于用户来说他感觉到的为什么页面打不开、为什么按钮点击不了、为什么图片显示这么慢。而对于工程师来说,可能关注的是DNS查询、TCP连接、服务响应等浏览器加载过程指标。我们根据用户的痛点,将浏览器加载过程抽取出四个关键指标,即白屏时间、首屏时间、用户可操作、总下载时间(定义可见上篇文章)。这些指标是如何统计的呢?

确定统计起点

我们需要在用户输入URL或者点击链接的时候就开始统计,因为这样才能衡量用户的等待时间。如果你的用户高端浏览器占比很高,那么可以直接使用Navigation Timing接口来获取统计起点以及加载过程中的各个阶段耗时。另外也可以通过cookie记录时间戳的方式来统计,需要注意的是Cookie方式只能统计到站内跳转的数据。

统计白屏时间

白屏时间是用户首次看到内容的时间,也叫做首次渲染时间,chrome高版本有firstPaintTime接口来获取这个耗时,但大部分浏览器并不支持,必须想其他办法来监测。仔细观察WebPagetest视图分析发现,白屏时间出现在头部外链资源加载完附近,因为浏览器只有加载并解析完头部资源才会真正渲染页面。基于此我们可以通过获取头部资源加载完的时刻来近似统计白屏时间。尽管并不精确,但却考虑了影响白屏的主要因素:首字节时间和头部资源加载时间。(极客君插播一条广告,哦不,问题! 问题是:关于获取数据这里,想要拿到精准的数据,就没有办法了吗?。。。稍后再谈,先看攻略。)

如何统计头部资源加载呢?我们发现头部内嵌的JS通常需等待前面的JS\CSS加载完才会执行,是不是可以在浏览器head内底部加一句JS统计头部资源加载结束点呢?可以通过一个简单的示例进行测试:

百度大神是如何在7 天内打造一个前端性能监控系统的?_第5张图片

经测试发现,统计的头部加载时间正好跟头部资源下载时间相近,而且换成一个执行时间很长的JS也会等到JS执行完才统计。说明此方法是可行的(具体原因可查看浏览器渲染原理及JS单线程相关介绍)。

统计首屏时间

首屏时间的统计比较复杂,因为涉及图片等多种元素及异步渲染等方式。观察加载视图可发现,影响首屏的主要因素的图片的加载。通过统计首屏内图片的加载时间便可以获取首屏渲染完成的时间。统计流程如下:

首屏位置调用API开始统计->绑定首屏内所有图片的load事件->页面加载完后判断图片是否在首屏内,找出加载最慢的一张->首屏时间

这是同步加载情况下的简单统计逻辑,另外需要注意的几点:

·页面存在iframe的情况下也需要判断加载时间

·gif图片在IE上可能重复触发load事件需排除

·异步渲染的情况下应在异步获取数据插入之后再计算首屏

·css重要背景图片可以通过JS请求图片url来统计(浏览器不会重复加载)

·没有图片则以统计JS执行时间为首屏,即认为文字出现时间

统计用户可操作和总下载

用户可操作默认可以统计domready时间,因为通常会在这时候绑定事件操作。对于使用了模块化异步加载的JS可以在代码中去主动标记重要JS的加载时间,这也是产品指标的统计方式。

总下载时间默认可以统计onload时间,这样可以统计同步加载的资源全部加载完的耗时。如果页面中存在很多异步渲染,可以将异步渲染全部完成的时间作为总下载时间。

网络指标

网络类型判断

对于移动端来说,网络是页面加载速度最大的影响因素,需要根据不同的网络来采取相应的优化措施,例如对于2G用户采用简版等。但web上没有接口获取用户的网络类型。为了获取用户网络类型,可以通过测速的方式来判断不同IP段对应的网络。测速例如比较经典的有facebook的方案。经过测速后的分析,用户的加载速率有明显的分布区间,如下图所示:

百度大神是如何在7 天内打造一个前端性能监控系统的?_第6张图片

各个分布区间正好对应不同的网络类型,经过与客户端的辅助测试,成功率可以在95%以上。有了这个IP库对应的速率数据,就可以在分析用户数据时根据IP来判断用户网络类型。

网络耗时统计

网络耗时数据可以借助前面提到Navigation Timing接口获取,与之类似的还有Resource Timing,可以获取页面所有静态资源的加载耗时。通过此接口可以轻松获取DNS、TCP、首字节、html传输等耗时,Navigation Timing的接口示意图如下所示:


百度大神是如何在7 天内打造一个前端性能监控系统的?_第7张图片

以上重点介绍了数据采集部分,这也是系统中最关键的一部分,只有保证数据能真实反映用户感知,才能对症下药提升用户体验。数据采集完之后我们可以在页面加载完之后统一上报,如示例:

Day 5:如何分析性能数据?

让数据会说话

而数据分析过程,如前一篇文章所述,可以从多个维度去分析数据。大数据处理需要借助hadoop、Hive等方式,而对于普通站点则任意一种后端语言处理即可。

均值与分布

均值与分布是数据处理中最常见的两种方式。因为它能直观的表示指标的趋势与分布状况,方便进行评估、瓶颈发现与告警。处理过程中应去除异常值,例如明显超过阈值的脏数据等。

耗时的评估中,有很多这方面的研究数据。例如有人提出三个基本的时间范围:

·0.1: 0.1秒是用户感知的最小粒度,在这个时间范围内完成的操作被认为是流畅没有延迟的

·1.0: 1.0秒内完成的响应认为不会干扰用户的思维流。尽管用户能感觉到延迟,但0.1秒-1.0秒内完成的操作并不需要给出明显loading提示

·10:达到10秒用户将无法保持注意力,很可能选择离开做其他事情

我们根据业界的一些调研,结合不同指标的特点,制定了指标的分布评估区间。如下图所示:


百度大神是如何在7 天内打造一个前端性能监控系统的?_第8张图片

评估区间的制定方便我们了解当前性能状况,同时对性能趋势波动做出反应。

多维分析

为了方便挖掘性能可能的瓶颈,需要从多维的角度对数据进行分析。例如移动端最重要的维度就是网络,数据处理上除了总体数据,还需要根据网络类型对数据进行分析。常见的维度还有系统、浏览器、地域运营商等。我们还可以根据自身产品的特点来确定一些维度,例如页面长度分布、简版炫版等。

需要注意的是维度并不是越多越好,需要根据产品的特点及终端来确定。维度是为了方便查找性能瓶颈

小插曲:之前从微博中看到有人评价说想做监控但是公司没有日志服务器。并不需要单独的日志服务器,只要能把统计的这个请求访问日志保存下来即可。如果网站自己的独立服务器都没有还有解决办法,在百度开发者中心新建一个应用,写一个简单的Web服务将接收到的统计数据解析存到百度云免费的数据库中,然后每天再用Mysql处理下当天的数据即可,对于普通站点的抽样性能数据应该没问题。请叫我雷锋。


Day 6:如何利用监控数据解决问题?

发现瓶颈,对症下药

对于图表制作,比较出名的有Highcharts,百度开发的Echarts也很不错。不管使用什么工具,最关键的一点就是让报表能突出重点,直观明了

制作报表前多问几个如何让人直观看到目前状况和可能存在的问题,哪些地方可以加强,哪些可以去掉,使用是否习惯等。

百度大神是如何在7 天内打造一个前端性能监控系统的?_第9张图片

有了能反映用户感知的真实世界、并且细分到各个业务功能,有详细的网络等辅助数据,我们在解决前端性能上便更加得心应手。监控系统已经对线上访问状况有了连续的反馈,根据现有评估与瓶颈选择对应方案进行优化,最后根据反馈进行调整,相信性能优化不再是个难题。

如何选择优化方案呢?这又是一个比较大的话题了,好在已经有很多经验可以借鉴。附录中就整理了部分性能的学习资料,可以根据需要阅读学习。

百度大神是如何在7 天内打造一个前端性能监控系统的?_第10张图片


Day7:总结

通过以上“几天”的努力,我们可以搭建一个小而美的前端性能监控系统。但这仅仅是开始,前端数据有很多挖掘的价值。性能优化也是一门需要认真学习的课程,为了打造流畅的使用体验,为了让用户更加满意,赶紧搭建起自己的前端数据平台吧!


————————福利来了!————————

                    前端性能学习资料整理


性能准则★★★★★

·雅虎性能军规、中文文章

·谷歌性能优化文章推荐

分析工具★★★

入门

·pageSpeed基于谷歌性能准则的检测,可浏览器安装插件运行

·Yslow基于雅虎性能准则的检测工具,可浏览器安装插件运行

·pageCheck百度内部开发,指标齐全,支持自动运行

进阶

·webPageTest查看页面加载瀑布流等数据,进阶必备工具

·Chrome开发者工具功能强大,值得学习

·PhantomJS功能强大的分析工具,高手必备瑞士军刀

·JsPerfJS执行性能分析网站,谁用谁知道

浏览器与Html标准★★

入门

·浏览器缓存机制

·Navigation Timing、Resource

Timing相关文章请谷歌,必备知识

·DNS解析过程原理

·高性能浏览器网络翻译系列

进阶

·SPDY协议基于此的Http2.0协议即将发布

·浏览器渲染原理比较难懂,但是非常经典

·Chrome实现原理学习指南多益大牛的总结

开发实战★★★★

通用

·高性能 JavaScript

·writing-fast-memory-efficient-javascript

·Understanding and Solving Internet Explorer Leak Patterns

·模块化加载FIS、SeaJS。FIS有完善的静态资源管理和优化方案,推荐。

·前端性能优化最佳实践

动画与渲染

·requestAnimationFrame

·16ms的优化

·css、JS不要引起Repaint & Reflow

移动端开发

·Improving the Performance of your HTML5 App

·Steve Souders

·Creating High-Performance Mobile

Websites

·HTML5 Techniques for Optimizing

Mobile Performance

·移动 web站点优化指南

性能监控★★★★

·监控指标选取

·Complete Web Monitoring - Web

Performance at eMetrics

·berserkJS建立前端性能监控平台

·NY Web Perf Meetup: Peeling the

Web Performance Onion

相关会议★★★

·velocity业内最出名的国际会议之一

·Google I/O

·Qcon

推荐博客`★★★`

·web performance today

·perfplanet

·stevesouders.com

·site-performance-and-optimization

                            (张大神分享结束,干货还在继续...)


刚刚看文过程中,极客君不礼貌的插播了一个问题:关于获取数据这里,想要拿到精准的数据,就没有办法了吗?关于这个,极客君有话要说。

一切问题都反应在数据中,正如张大神所讲的,在“采集数据→发现问题→定位瓶颈→各个击破”的逻辑链条中,采集数据是一切的根源,相应的,数据的准确度也尤为重要

其实目前(不光国内,国外也是)针对页面速度普遍存在的一个行业痛点是:衡量web的页面加载时间不精准,有很大误差,极端情况超过10秒。而对手机APP,现在根本没有没有工具可以衡量app的页面加载时间。

性能极客的“感知性能算法”全球率先解决上述痛点,高精准的还原页面加载进程和定义加载时间。请看以下评测精度对比:

百度大神是如何在7 天内打造一个前端性能监控系统的?_第11张图片

所以说,选对工具才是关键!


极客 web

网页测速|网页性能评测|精准定位性能瓶颈|全站优化|全球性能监控|故障预警|自定义预警条件|竞品对比

·白屏时间√

·首屏时间√

·页面加载渲染时间√

·页面加载瀑布图√

·关键帧分析√

·竞品对比√

·实时监控√

·全站优化√


周边阅读:

说说全站优化的那些事儿?

科普|网站性能指标知多少?

干货|  Web前端优化的强者之路

更多消息,关注性能极客官网。

你可能感兴趣的:(百度大神是如何在7 天内打造一个前端性能监控系统的?)