移动app网络和性能应该如何监控

APP性能需要在上线前进行性能测试,主要有这几个方面(以下例举):

1.安全、启动时间;

2.CPU占用;

3.内存占用;

4.流量耗用;

5.电量耗用;

 在移动端开发者中最重要的KPI应该是崩溃率。当崩溃率稳定下来后,工作的重心就应该转移到性能优化上。那么问题来了,如果你的项目也没有接入任何性能监测SDK,没有量化的指标来衡量,那你说你优化了性能领导信么?

虽然现在市面上第三方性能检测平台已经很成熟,但笔者还是比较建议公司自己写自己的sdk,原因如下:

1. 数据安全

2. 避开费用,有的平台是MAU三万以下不收费,超出后费用极高。

3. 可以自定义指标没有无用代码,一接别人SDK包体积增大不少,其实你只用到了个别几个功能。

本文主要内容是给小项目团队自己写性能sdk的建议,也会提到当前的第三方平台。

1.页面的打开速度

关于页面的加载速度的测量有两个指标,一个是页面渲染速度,一个是页面加载速度。

页面渲染速度就是计算一个viewcontroller从viewdidload的第一行到viewdidappear的最后一行所用的时间。 这种方法可以适用于大多数相对静态的页面,一打开就直接加载的。  

页面加载速度相对比较麻烦,适用于有些页面并不是一进入就加载而是先发个请求,请求回调后才继续搭建页面的。加载时间应该是用户点开页面到用户能完全的看到内容才算加载完毕,这里就需要算进去请求消耗的时间了,对于源码级别的sdk,我们可以通过每发出一个请求就记到栈里,回调一个消除一个,当栈里的每一个请求都已经回调后才能认定是界面加载完毕。 业界也有一些黑盒的云测平台是录屏解析视频流,认定一个页面从打开到页面稳定后为加载时间。 个人认为肯定没有源码级别的准啊。 (董铂然博客园)

关于这种接入一个sdk直接hook每个页面生命周期方法也简单提一下吧,就是写一个类作为UIViewController的分类,增加几个方法如XXXviewdidload , XXXviewdidappear等,然后使用这种swizzle的做法替换方法的实现

对于一些新增的计量属性就使用运行时关联对象的那一套吧。 如果觉得要hook的方法太多或是太麻烦或是怕和别的hook冲突,可以使用埋点的方式,直接埋上你需要计算的开始和结束时间的采集点,这种更加灵活只关心自己关心的页面。


2.内存使用值

关于内存和cpu的获取方法业内基本都有统一的代码了,大致如下。

需要先引入这两个头文件

获取到了数据存入数组那接下来的事情就是上报策略的制定了。没必要每次获取数据都上报,可以设置每次启动上报上一次session的全部记录就好,启动后隔个10秒或20秒错开请求高峰期。上报时的数据结构也要尽可能的精简,因为不能对用户的流量造成太大的损失,也可以选择先压缩后再上传。

3.CPU占用率

同样需要内存的那两个头文件

关于采集数据的频率完全是自己制定的,而且大部分app都是在刚启动不久内cpu占用较大 之后就渐渐区域稳定,所以建议在刚开始采集间隔短一点比如1s,之后采集间隔逐渐加大最后稳定到5分钟获取一次。


4.页面的帧率

这个测量页面帧率的做法就是通过这个CADisplayLink刷帧方法的调用次数计算的,一般这个方法最快能每秒调用60次,如果是CPU或是GPU某个步骤耗时导致渲染错过了一次垂直信号,那这个方法就不会被调用了,之后统计的帧数也就随之降低了。 上面代码中的fps就是求出的这一时刻的帧率可以塞入数组再稍作处理上传。这里需要注意的是 性能监测平台自己对性能的影响,这个统计帧率的方法可能相对来说要耗性能一些,所以需要控制在某些时刻采集一定的样本就及时暂停。  这个数据建议hook每个页面加载时的方法如viewwillappear,或是tableview滑动时的代理方法,因为卡顿大多发生在这两个场景。 对帧率有兴趣的可以做一个悬浮窗测试帧率,我之前写过一个,但是还没有抽离成组件有兴趣的可以交流下。

5.url响应时间监控

这里普通的做法就是继承NSURLProtocol 这个类写一个子类,然后在子类中实现NSURLConnectionDelegate 的那五个代理方法。 

(经过调研connection在升级ipv6后还是可以使用的)你可以得到请求的url,建议只记录host和path,因为吧拼上的参数也上传第一不好快速分类,第二服务端还要做截取处理增加压力,第三浪费流量。 也可以得到response包的length。 响应时间可以根据结束方法中的时间减去开始方法中的时间得到,然后以key-value的方式上传。个人觉得请求没必要与viewcontroller关联,要考虑到管理页面栈还要考虑present和dismiss,收效甚微。并且想知道哪个url属于哪个页面还有很多可执行的方案。

关于webView的url响应时间监控,比普通的native内url要复杂一些。 虽然上面说的统计方法也可以统计到webview的url响应时间,但是只能统计到完整url时间。webView的打开时可能会伴随一些302跳转之类的url,最后才到目标url。 如果一个url经历了三次跳转,响应时间很长,用上面说的统计方法只能统计总时间并不能定位到具体是哪一个子url异常。 这时就需要webView内特殊的时间统计了。

有的一个url会调多个不同团队维护的服务导致了重定向(图中ABC都是完整url的子url),分别在webView的两个代理方法中埋点计算差值,从A走了didstart到B走了didstart这个时间的差值为①就是A所消耗的时间,①+②+③是完整的时间。 通过这种分离统计的方法,可以把慢url明确定位到每一个服务,不对拖累好人。


6.请求错误码统计

如果没有做错误码统计的话,你服务器有问题或者某些地区被运营商劫持之类的,你app的界面可能显示的就是一直转菊花,这时是无法精确定位问题的。 所以将自己的请求都进行编号并收集错误码是非常有必要的。 我们所关注的错误码有三种:

1. 正常的HTTP Response code 比如200 ,404,500   

2. AFN(现在ASI用不了了,ipv6强制升级后 应该大部分人都是用AFN3.0了)指定的code 如 -1101, 1102等

3. 你自己请求制定的errorcode。 如 errorcode : 7, message : "您还没有登录" 或 errorcode:10,message:"签名验证失败" 

还有很重要一点,就是将自己的所有接口做成一整套映射的编号, 举个例子67对应的是persondetail接口。出现了请求错误,上传的请求错误码应该包含两个部分:接口编号+错误编号。 错误编号建议优先使用自己制定的errcode,其次是AFNcode,最后才是HTTPresponsecode。

“67-10” “35-404” 如果以后上报了类似的错误码,当然比只看到转菊花要好定位的多。


最后提当下的第三方性能监控平台,有听云,OneApm,博睿。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,005评论 25 707
  • WebView·开车指南 2016-08-31BugDev 北京市东城区首席Bug布道师开山之作,一整月交通事故血...
    53c021c38a1d阅读 828评论 0 1
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139
  • 买大额保险是没用的… 保险现在已经大为普及,很多人也购买了大额保险,但有没有想过,购买了大额保险,万一有个万一时,...
    KStoriesColon阅读 609评论 0 0
  • 是不是每个人心里都住着这样一个人,相见不敢见,想念不敢念。一直放不下,永远得不到。 当帽帽获知要去上海参加...
    也好也不好阅读 331评论 0 0