常用流量测试方法及一些思考

导读

app性能测试中流量测试是其中重要的一项,网络场景(wifi、非wifi)、用户使用场景(页面加载流量、场景使用流量、待机流量),这些都是需要考虑的测试点。

各个业务的产品形式不同,因此场景选择及流量目标需要根据项目实际情况来进行。本文主要讲解一些常用的流量测试方法,以及在测试过程中获取到一些可以协助分析定位的信息。

常用APP流量测试方法

App的流量测试方法有很多种,说起流量测试,也许大家的第一反应就是tcpdump/wireshark这类网络抓包工具。的确,Android系统确实也支持tcpdump工具,通过tcpdump,我们可以实现非常精准的流量测试。其实,对于特定apk的整体流量数据,在Android系统中都会存储到对应文件中,我们完全可以通过读取对应文件来获得当前apk的流量信息。

方法一

——android系统自带统计功能

通过直接读取android系统上的两个文件的内容:Proc/uid_stat/{UID}/tcp_snd和tcp_rcv,其中UID是每个app安装时分配的唯一编号用于识别该app,tcp_snd中的数据表示发送的数据累计大小,单位是字节,tcp_rcv表示接收到的数据累计大小。

通过adb命令进入shell可以获取到这些数据。

(1)首先通过包名获取app的PID;

(2)再访问/proc/{PID}/status文件查找app对应的UID;

(3)在通过UID号加上10000号查看接收和发送的流量文件;

这个做法也是很多手机安全软件的做能比较简单的给出各个app的流量消耗情况,如果我们只关注总体的流量数值还好,但要是我们希望能测试得到更细化的数据,该方法就没法满足我们的测试需求了。

方法二

——wireshark+tcpdump

常用的在手机上抓包的工具是wireshark和liunx下的tcpdump。Tcpdump抓包需要root权限,ios的话需要越狱。

(1)在一台root手机上先下载tcpdump可执行文件,通过adb push命令上传到手机上。有时候直接push到/data目录下会存在权限问题,这个时候可以先将tcpdump文件push到sdcard,在从sdcard中将文件cp到/data/local目录,其他目录下的权限问题较多。在将tcpdump文件赋读写权限。

(2)然后可以进入tcpdump所在目录执行命令抓包了, ./tcpdump -s 0 -w ./t1.pcap -v。

上方这个Got的数据会随着访问不断变化。

关于tcpdump的命令可以参考命令手册,不再展开,上面的几个参数的含义:

  • -s 0:默认抓取长度是68字节,加上-s 0过后可以抓到完整的数据包。
  • -w ./t1.pcap:将抓到的内容存入t1.pcap文件。
  • -v:在抓包过程中显示抓包的数量。就是Got旁的数据。

(3)抓包结束后,将t1.pacp传到电脑用wireshark分析工具进行查看和分析。

方法三

——GT工具

GT(随身调)是APP的随身调测平台,它是直接运行在手机上的“集成调测环境”(IDTE, Integrated Debug Environment)。利用GT,仅凭一部手机,无需连接电脑,您即可对APP进行快速的性能测试(CPU、内存、流量、电量、帧率/流畅度等等)、开发日志的查看、Crash日志查看、网络数据包的抓取、APP内部参数的调试、真机代码耗时统计等。GT中的抓包工具就是对方法二tcpdump进行的易用性封装,无需连接电脑,随时随地随心所欲的抓包。关于更多的使用方法请查阅http://gt.qq.com/index.html。

如何进行流量测试的分析

单纯只测试出一个总体的结果,不管是给我们自己进行分析或是丢给开发定位,给到的信息都是不够的。那使用什么样的方法可以在测试流量的过程中,同时获取到一些便于我们分析和定位的数据呢?

下边跟大家说说我是如何思考和实践的:

流量测试既关注域名的流量消耗,又关注协议的流量消耗。对于域名的流量消耗,只需通过抓包后,再利用现有工具统计不同域名下的流量消耗即可。

但是协议的流量消耗呢?如何统计不同域名下的不同协议拉取频率和每次拉取的流量消耗?如何定位拉取频率是否过高,是否有某次摘取流量消耗异常过大呢?

我们的测试策略是:需要在有网络请求的地方把相关协议名称、请求ID、请求大小、回包大小通过本地协议日志文件输出,再接合抓取的包进行解析,根据请求ID来确认该域名的协议名称。

如下图所示:

测试结果得到域名流量和协议流量文件,基于域名流量统计主要目的是便于发现某个服务器是否存在流量消耗过大;基于协议流量统计主要便于发现某个协议是否存在流量消耗过大或者协议拉取较频繁的现象。

版权所属,禁止转载

原文发布于微信公众号 - 腾讯移动品质中心TMQ(gh_2052d3e8c27d)

原文发表时间:2018-03-05

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏iOSDevLog

应用程序内购买教程:入门

更新说明:Pietro Rea为Xcode 10,Swift 4.2和iOS 11/12更新了本教程。Ray Wenderlich写了原文。

1162
来自专栏北京马哥教育

Linux 下使用 Sar 简介

介绍 Sar 最早是实现在 Salaris Unix 系统里,后来移植到了大部分其他的 Unix 系统(如AIX,HP-UX等)。Linux 下也有法国人写的 ...

3457
来自专栏FreeBuf

在线恶意软件和URL分析集成框架 – MalSub

malsub是一个基于Python 3.6.x的框架,它的设计遵循了当前最流行的互联网软件架构RESTful架构,并通过其RESTful API应用程序编程接口...

18710
来自专栏农夫安全

用手机轻松刷洞,移动端开源安全测试工具合集

用手机轻松刷洞,移动端开源安全测试工具合集 ? 随着移动互联网的迅速发展,移动安全也慢慢成为了新的热门行业,以往移动应用的安全测试大多是使用在线检测平台或者...

5018
来自专栏FreeBuf

iOS核心应用设计漏洞,暴露用户Apple ID凭证

Check Point提醒苹果iOS的核心应用程序可能会暴露用户的凭据。所幸的是iOS 9包含有相关的补丁。 Apple ID ios操作系统专门为用户提供了...

1908
来自专栏张善友的专栏

探究基于声明的身份标识

    大多数企业应用程序都需要一些基本用户安全功能。它们至少需要验证其用户身份,其中有很多还需要授权访问特定功能,以便只有那些有特权的用户才能使用它们。有些应...

1726
来自专栏XAI

初识Bluemix-基于Bluemix快速开发可具有Watson认知能力的IOT应用

参与IBM的“第八格”技术论坛,体验了一把基于Bluemix如何快速将一个IOT服务应用开发出来,用Node-red工具创建一个可视化应用。 NODE-RED ...

1728
来自专栏IMWeb前端团队

使用flv.js做直播

为什么要在这个时候探索flv.js做直播呢?原因在于各大浏览器厂商已经默认禁用Flash,之前常见的Flash直播方案需要用户同意使用Flash后才可以正常使用...

1.1K7
来自专栏Youngxj

余闻同学录3.2.0破解版网站源码

1773
来自专栏向治洪

android 使用Vysor投影到电脑

有没有好的投影软件可以将android屏幕投影到电脑,当然这种很多,比如360就自带了投影功能,小米盒子也可以(不过貌似只能支持到4.4版本),今天要说的是Vy...

26010

扫码关注云+社区