h5性能测试实践结果分析

背景

由于在标准组件参与了比较多运营活动h5页面的性能测试,在终端h5测试过程中发现随着移动设备和网络环境的复杂,使得性能测试越来越重要,所以在此对H5页面的性能测试结果(以及容易出问题的点),做一个总结,给H5测试的同学一个参考。

h5原理了解

  • 手机接入服务器流程

首先,手机要通过无线网络协议,从基站获得无线链路分配,才能跟网络进行通讯。 无线网络基站、基站控制器这方面,会给手机进行信号的分配,已完成手机连接和交互。 获得无线链路后,会进行网络附着、加密、鉴权,核心网络会检查你是不是可以连接在这个网络上,是否开通套餐,是不是漫游等。核心网络有SGSN和GGSN,在这一步完成无线网络协议和有线以太网的协议转换。 再下一步,核心网络会给你进行APN选择、IP分配、启动计费。 再往下面,才是传统网络的步骤:DNS查询、响应,建立TCP链接,HTTP GET,RTTP RESPONSE 200 OK,HTTP RESPONSE DATA,LAST HTTP RESPONSE DATA,开始UI展现。
可见:通过运营商的网络上网,情况比较复杂,经过的节点太多;运营商的网络信号强度变化频繁,连接状态切换快;网络延迟高、丢包率高;网络建立连接的代价高,传输速度快慢不等(从2G到4G,相差很大)

  • h5页面执行过程

1、解析HTML结构。
2、加载外部脚本和样式表文件。
3、解析并执行脚本代码。// 部分脚本会阻塞页面的加载
4、DOM树构建完成。//DOMContentLoaded 事件
5、加载图片等外部文件。
6、页面加载完毕。//load 事件
一句话就是:请求HTML,然后顺带将HTML依赖的JS/CSS/iconfont等其他资源一并请求过来。

  • h5需关注性能耗时数据说明

通过上面这个这个原理,我们可以知道最主要要关注的性能数据:请求数量 与 请求大小和各事件加载时间。

  • cpu
    当页面中资源样式复杂,强调视觉效果时,测试员可观察CPU占用率来反映H5绘制质量。如果CPU长期处于高占用率,可考虑降低高计算量的视觉效果等手段。
  • 内存
    帧率尤其在有视频和动画效果的H5中,测试员应该重点关注,防止严重的卡顿流出。
  • 首资源下载时间
    从开始下载到第一个资源均下载完成的时间,不包括页面绘制时间。
  • 总资源下载时间
    从开始下载到所有资源均下载完成的时间,不包括页面绘制时间。
  • 用户可操作时间
    从页面开始加载到用户操作可响应的时间。
  • 白屏时间
    用户首次看到网页有内容的时间,即第一次渲染流程完成时间。
  • 首屏加载时间
    即在可见的屏幕范围内,内容展现完全,loading进度条消失。因此在H5性能优化中,一个很重要的目的就是尽可能提升这个“首屏加载”的时间,让它满足“一秒钟法则”。
  • 页面渲染时间
    performance.timing.domComplete-performance.timing.navigationStart就可以打印出网页加载的时间,domComplete表示所有的处理都已完成并且所有的附属资源都已经下载完毕。navigationStart表示开始加载新页面。两者相减,就代表这个网页完成渲染所需要的时间了。

整理成xmind截图如下:

性能测试点.png

实践过程及分析

测试工具:

iPhone :iPhone + Mac + safari + 数据线调试普通页面 or charle抓包工具结合
Android:主要是chrome的inspect(注意:Android版本需要是4.4+,并且应用中的WebView必须进行相应的调试声明配置)或者charles抓包工具结合

常见测试案例

  • 发现请求流量大\请求数量多\图片未压缩的问题:

【操作步骤】
1、正常网络下,首次打开加载运营模版抽奖测试页面
2、在chrome观察load时间,请求图片大小,个数数据
【预期结果】
耗时:页面全部资源加载完成<3s
大小:单张图片<50k
像素:图片像素不超过640px
格式方面:webP优于JPG ,JPG优于PNG,PNG优于GIF
总请求流量:<200k
【实际结果】
耗时:页面全部资源加载完成3.8s
大小:单张图片最大的有1m
像素:图片像素超过640px
格式方面:png格式
总请求流量:1.3m
【可能原因分析】
1、对于jpg,png格式图片来说本身就已经经过了压缩还有1m多,远远不符合预期要求,可能需要更加优化的压缩算法来优化
2、流量类问题,直接导致页面加载速度慢或者交互响应慢、卡顿

  • 发现内存泄漏问题:

【操作步骤】
1、运营抽奖模版主页面反复随机操作,比如反复点开/关闭页面,btn按钮点击功能的反复操作,上下拉刷新操作
2、chrome抓包timeline内存曲线是否为增长型即观察内存变化状况是否一点点上涨,观察dom节点数,heap timeline,可以粗略地判断是否有内存泄漏
【预期结果】
Js heap :有波动(内存释放)
内存视图:轮廓扁平
dom节点数:返回到原来数目(正常)
heap timeline中,最后色柱应该是灰色的表示这个对象在timeline中生成,但结束前已经被回收
【实际结果】
Js heap:无波动,直线
内存视图:轮廓有棱角锋利
dom节点数:未返回到原来数目(可能存在内存泄露)
heap timeline中,有两条蓝色柱被保留,潜在内存泄漏

  • 发现卡顿问题:

【操作步骤】
1.登录进入活动页,快速上下滚动加载图片数据等
2.查看页面,抓包,chrome profile分析,观察fps
【预期结果】fps高于60
【实际结果】主页:正常网络测试fps均低于40,存在卡顿现象,其中抓包分析timeline发现core.js存在卡顿现象较严重:fps低于30,76.230 ms
【可能原因分析】
1、页面内元素有未处理的touchmove事件冒泡给了documentbody,导致页面滑动时频繁触发事件;
2、还有一种可能是移动端页面上大量应用一些伪元素来模拟原生效果,比如0.5px的线条,如果布局不合理很有可能在页面滚动时造成大面积paint,gpu ram瞬间飙涨,fps极速下降
3、卡慢问题中,流量(过大)类占比过半

以xx app运营活动签到送流量h5页面测试为例

测试案例记录.png

结论总结

根据多次h5页面性能测试经验及行业参考标准,整理出性能指标如下xmind截图可供参考测试:

性能指标.png

时间: 2024-10-28 09:04:10

h5性能测试实践结果分析的相关文章

滑屏 H5 开发实践九问

  滑屏的交互形式自从在 H5 中流行起来,便广泛应用在产品宣传.广告.招聘和活动运营等场景中,作为微信朋友圈广告惯用的形式,其影响力更是得到了强化与放大.如今滑屏H5可谓玲琅满目,数不尽数. 作为一个 UI工程师,接过很多类似的项目,也曾写过滑屏的插件,在经历了不同的需求的"洗礼"并踩过若干个坑之后,不禁反问自己:应该如何面对每一次类似的需求,在已有的经验下如何做到体验更好?如何节省工作量提高效率?面对性能优秀的 iOS 与性能良莠不齐的 Android 平台,又如何做到体验统一与性

Android 性能测试实践(一)

前言: 前段时间花了两周的时间做了一个基于Android 客户端的性能测试现在分享给大家,希望对大家有所帮助! Look-Look 1,既然是基于Android客户端的性能测试那就与后台的一些API.数据接口要区分开来~! 2,Android的性能测试能其实包括很多很多的测试项比如:资源消耗,内存泄露,电量功耗,启动耗时,渲染等等.... 怎么去做? 1,采集数据 :采集的数据包括:内存.cpu.电量功耗.hprof(内存泄露分析文件).响应时间等等.... 2,设计场景 :搞定数据的采集后配合

Android笔记之:App调试的几个命令的实践与分析_Android

在Android的应用开发中,我们会用到各种代码调试:其实在Android的开发之后,我们可能会碰到一些随机的问题,如cpu过高,内存泄露等,我们无法简单的进行代码调试,我们需要一个系统日志等等,下面我把握工作中碰到的几个常用命令和方法给大家演示实践一下. 1.logcat命令这个命令最简单常用,可查看帮助,我不多说,如果需要打印时间,加参数-v time adb logcat -v time 2.bugreport命令这个命令也非常简单,但是在实际应用中非常有用,会有从开机之后详细的dumps

性能测试需求指标分析方法

六.设计测试模型 1.业务模型的设计 一个系统的业务模型是通过业务调研获得,业务模型的正确性反映在两个方面首先业务选择的正确性和业务比例的正确性. 首先业务选择,一个系统可能支持几百个业务活动(也有叫做交易)但是只有少数的业务活动非常频繁,占总业务量的80%以上,那么在性能测试时只需关心这些占了大部分业务量的少量业务上. 其次业务比例,如何精确统计业务的数量是关键问题,针对一个全新的系统可能要通过对使用系统的涉众进行调研,搞清楚他们群体数量,操作行为周期.在通过组合这些数据确定在常规业务日中各种

实践测试分析网站恢复排名的简单方法

大家好,我是哈尔滨虚实网站设计,这几天一直在研究恢复网站关键词的办法,经过几轮的测试,最终感觉还是老办法好,其实我们做优化的时间长了,很容易忽略最原始的办法,就是更新首页,引蜘蛛爬行,分析竞争对手关键词密度和排放位置,看看他们的外链建设,最终进行调整,经过几次的分析,发现前面的几个站并没有什么特殊的地方,无论是站内优化还是站外链接,但是有一点和我不一样,那就是首页会经常的更新,不知道是不是这个缘故,下面我解析下我是如何分析的. 前几天我分析了自身网站的一些问题,比如更换服务器,网站更新,检测友情

基于Dojo DOH框架的Javascript性能测试实践

DOH 框架介绍 Dojo 作为一个功能丰富.高度模块化的 JavaScript 库,注定需要 大量的单元测试来确保每一个功能模块的稳定.Dojo 自带的单元测试框架 DOH(Dojo Objective Harness)为编写各类单元测试提供了坚实的基础.开发者可以利用 DOH 框架快 速地编写以下单元测试: 普通 Javascript 单元测试 异步 Javascript 单元测试 Javascript 性能测试 Web UI 交互测试 其中,通过 DOH 普通 Javascript 单元测

php中serialize序列化与json性能测试的示例分析_php实例

最近需要对大数组做存储,需要在serialize序列化和json之间做了选择.因此需要做了性能测试. 在php5.2之前对数组存储的时候,大都使用serialize系列化.php5.2之后,开始内置了 JSON 的支持. 在网上看到有些资料说:json_encode和json_decode比内置的serialize和unserialize函数要高效.耳闻不如眼见,眼见不一定为实.那就用实际数据测试吧..... 我们先理解概念: 一. 序列化 序列化是将对象状态转换为可保持或可传输的格式的过程.与

动态网络负载平衡集群实践应用分析

网络负载平衡允许你将传入的请求传播到最多达32台的服务器上,即可以使用最多32台服务器共同分担对外的网络请求服务. 网络负载平衡技术保证即使是在负载很重的情况下它们也能作出快速响应.网络负载平衡对外只须提供一个IP地址(或域名).如果网络负载平衡中的一台或几台服务器不可用时,服务不会中断. 网络负载平衡自动检测到服务器不可用时,能够迅速在剩余的服务器中重新指派客户机通讯.此保护措施能够帮助你为关键的业务程序提供不中断的服务.可以根据网络访问量的增多来增加网络负载平衡服务器的数量.网络负载平衡可在

(&amp;#160;转)性能测试--地铁模型分析

地铁模型分析 和绝大部分人一样,小白每天都要乘坐地铁上下班,那么就拿地铁来分析,再次深刻理解下性能.早上乘坐地铁上班,最典型的就是北京地铁1.5.10.13号线等,人多得简直没法形容!为了方便理解分析,先做如下假设. 某地铁站进站只有3个刷卡机. 人少的情况下,每位乘客很快就可以刷卡进站,假设进站需要1s. 乘客耐心有限,如果等待超过30min,就会暴躁.唠叨,甚至选择放弃. 按照上述的假设,最初会出现如下的场景. 场景一:只有1名乘客进站时,这名乘客可以在1s的时间内完成进站,且只利用了一台刷