前段时间接手了一个 web 前端性能优化的任务,一时间不知道从什么地方入手,查了不少资料,发现其实还是蛮简单的,简单来说说。

一.前端性能测试是什么?
前端性能测试对象主要包括:

HTML、CSS、JS、AJAX 等前端技术开发的 Web 页面

影响用户浏览网页速度的因素主要有:

服务端数据返回、网络传输、页面渲染等

前端性能测试目的:

计算出包含页面渲染、网络传输以及服务器端解析等综合因素在内的加载时间指标,对该页面性能进行评估分析,找出影响性能的主要因素和瓶颈,并在此基础上,给出一定的优化建议和解决方案,从而提升用户体验

前端性能优化主要工具:

页面结构分析工具YSlow/PageSpeed

通过网页 JS/CSS/Image 数及请求数量、请求类型、缓存等方面的静态分析 ,多用于本地开发或者本地测试

真实用户浏览页面分析OneAPM Browser Insight

通过真实浏览器访问页面,收集页面的 w3c 标准信息,ajax,网络等数据等终端分析,多用于内网多终端系统检测和 web 网站检测

二.静态分析——Yslow(业界俗称:雅虎评估网站性能的23条军规)

通过给浏览器安装 Yslow 插件并开启后,在控制面板里就会给你评分提示,和改进建议。

YSlow 的 Grade (等级视图)

Yslow 给出的网站性能评分是从 F~A,A 最优、F 最差,通过上图的测试博客来看,网站有 4 处得分最低,例如上图中的最低分提示:我博客的 HTTP 请求太多。其中应用了 14 个外部 js、3 个 CSS 文件(之前我已从 6 个合并为 3 个)、14个 CSS 背景图片。

Yslow 的建议是让我合并这些,至于合并 CSS 引用图片我在“提高网站打开速度的7大秘籍”中介绍过。

Yslow Components(组件视图)

可以通过 Components 考验查看网页各个元素占用的空间大小。例如我博客某个页面,有 236 个 images(图片),占用了 489.2 K,通过详细查看,发现来自 gravatar 头像的引用图片非常大,再加上博客本身评论量就大,每个头像就占用几 K,几百个就占用了整个网页 50% 的大小,而且图片还是引用的,加载就更慢。

所以,得出的结论是:gravatar 虽然增强了互动性和个性,但也结结实实影响了网站速度。

Yslow Statistics(统计信息视图)

上图左侧图表显示的是页面元素在空缓存中的加载情况,右侧为页面元素使用缓存后的页面加载情况。从图中可以直观的看出(尤其是我标的红框),这个网页有 263 个 HTTP 请求,网页的大小达到 773.9K ,意味着每打开一个页面几乎需要下载 1M 的东西,而通过使用缓存后我们可以看到效果图片基本靠缓存,而网页总大小压缩到 43.2K 。

Statistics 这个统计信息视图工具和 Components (第三选项卡)一样,只是效果更直观,如果要获得性能优化建议还是要看 Grade (第二选项卡)的详细建议。

三.终端分析:OneAPM Browser Insight/业界俗称—real user monitoring

通过各种语言探针给页面自动插入 js 代码,在浏览器浏览的时候收集页面加载时间和网络信息,多用于内网多终端系统检测和 web 网站.

主要性能指标:白屏时间、首屏时间、资源加载完成时间、网页加载完成时间

OneAPM 的 Browser Insight 做的不是简单的把 window.performance 的数据采集过来然后报上去,它们从网页打开的整个过程区分了四个响应时间,具体的划分标准每个页面都有标注。为了避免某一次访问的特殊情况拖慢了整个平均时间,用户还可以结合下面的定位分析功能一起来看。

从整体趋势查看页面性能——定位分析

其实大多数互联网公司之所以优化前端网页,关心的是大多数打开自己的网页是否流畅,一两个个例并不在他的考虑范围之内或者说并不是当务之急。

定位分析功能实现了按响应时间把用户体验进行分区,包括 Apdex 指数分区和 W3C 页面加载时间标准分区,通过分区可以清晰的定位用户体验群体,根据不同的群体查看应用性能区间,包括网络、服务器请求排队、Web 应用处理耗时、网页构建耗时、资源加载耗时,同时可以多维度的查看用户体验区间的影响范围

慢加载追踪—瀑布流图

页面加载缓慢大家都能感觉出来,可是,是服务器的原因?是网络的原因?是页面资源加载的原因?是哪个图片加载的慢?这些问题 OneAPM 的慢加载追踪解决的都比较好。上几张干货图!

必须得说这个做的真心棒!界面做的很漂亮,还很详细,安卓 4.3 版本以上的微信浏览器也都能监控!

好了今天就简单说这些,之后有机会我们再聊~拜拜了各位~

【转】两款 Web 前端性能测试工具的更多相关文章

  1. 两款较好的Web前端性能测试工具

    前段时间接手了一个 web 前端性能优化的任务,一时间不知道从什么地方入手,查了不少资料,发现其实还是蛮简单的,简单来说说. 一.前端性能测试是什么 前端性能测试对象主要包括: HTML.CSS.JS ...

  2. 利用Docker安装Web前端性能测试工具Sitespeed.io

    目录结构 一.Sitespeed.io概述 1.Sitespeed.io简介 2.Sitespeed.io使用场景 二.Sitespeed.io的安装和使用 1.安装Sitespeed.io 2.连接 ...

  3. Docker安装Web前端性能测试工具Sitespeed.io

    一.Sitespeed.io概述 1.Sitespeed.io简介 Sitespeed.io:是一款开源的Web性能测试工具,用来衡量Web网站的综合性能,帮助开发和测试人员分析网页的加载速度和渲染性 ...

  4. Web Service 性能测试工具比较

    背景 希望选择一款Web Service性能测试工具,能真实模拟大量用户访问网站时的请求,从而获取服务器当前的请求处理能力(请求数/秒).以微信服务器为例,每个用户用独立的登录token,做各种操作, ...

  5. 性能测试工具 Web Service 性能测试工具比较

    [转自]https://testerhome.com/topics/3003 背景 希望选择一款Web Service性能测试工具,能真实模拟大量用户访问网站时的请求,从而获取服务器当前的请求处理能力 ...

  6. [转]10款 Web 开发常备工具

    文章地址:https://my.oschina.net/u/2903254/blog/798135 工欲善其事,必先利其器.如今 Web 开发标准越来越高,Web 开发者也在不断寻找途径提升自己的技能 ...

  7. [原创]H5前端性能测试工具介绍

    [原创H5前端性能测试工具介绍 一 网络抓包工具 网络抓包工具选择原则,可以捕获网络请求,抓取具体请求信息流,同时可以针对网络请包进行修改或拦截: 1.Fiddler(推荐) 2.Charles(推荐 ...

  8. sitespeedio前端性能测试工具介绍

    很久没有写博客了,今天给大家介绍一款比较好用的前端性能测试工具. sitespeedio简介: sitespeed.io是Jonathan Lee发布的一款可监视和衡量网站前端性能的开源工具. 1.开 ...

  9. Nikto是一款Web安全扫描工具,可以扫描指定主机的web类型,主机名,特定目录,cookie,特定CGI漏洞,XSS漏洞,SQL注入漏洞等,非常强大滴说。。。

    Nikto是一款Web安全扫描工具,可以扫描指定主机的web类型,主机名,特定目录,cookie,特定CGI漏洞,XSS漏洞,SQL注入漏洞等,非常强大滴说... root@xi4ojin:~# cd ...

随机推荐

  1. Android API 指南

    原文链接:http://android.eoe.cn/topic/android_sdk Android API 指南 - Android API Guides 应用的组成部分 - Applicati ...

  2. Spring MVC+Hibernate JPA搭建的博客系统项目中所遇到的坑

    标签: springmvc hibernate 2016年12月21日 21:48:035133人阅读 评论(0) 收藏 举报  分类: Spring/Spring MVC(6)  Hibernate ...

  3. 标准差(Standard Deviation) 和 标准误差(Standard Error)

    本文摘自 Streiner DL.Maintaining standards: differences between the standard deviation and standarderror ...

  4. SQL Server 的动态语句(SQLServer 的String.format用法)(SQLServer的调用SQL占位符的使用)

    直接上代码好了: --建表语句if exists(select 1 from [你的测试数据库名字].sys.tables where name='TDepartment') BEGIN print ...

  5. mysql中delimiter

    delimiter xx 其实就是告诉MySQL解释器,该段命令已经结束了,mysql是否可以执行了.默认请况下delimiter是分号';'.

  6. checkpoint and savepoint in FlinK

    https://info.lightbend.com/rs/558-NCX-702/images/preview-apache-flink.pdf https://www.microsoft.com/ ...

  7. mysql protocol

    http://hutaow.com/blog/2013/11/06/mysql-protocol-analysis/ https://dev.mysql.com/doc/internals/en/cl ...

  8. [DIOCP3-IocpTask说明书]基于IOCP引擎的多线程任务的投递和回调处理单元

    [说明] IocpTask是基于Iocp引擎的多线程任务投递和处理单元,可以方便的把任务进行投递到IOCP线程进行统一调度和处理,是模仿QDAC-QWorker的处理方式,支持D7以上的版本. [使用 ...

  9. 【ARM】2410裸机系列-中断处理

    目的 为了更好地掌握S3C2410中断的原理及中断程序的编写. 内容利用S3C2410的外部中断0和外部中断1实现两个按键功能 原理 本次选择的是外部中断EXTINT0和EXTINT11.中断的产生分 ...

  10. JS中的history对象

    window.history指向History对象,它表示当前窗口的浏览历史. History对象保存了当前窗口访问过的所有页面网址. history.back()//后退到前一个网址 等同于 his ...