• UID5201
  • 登录2017-10-18
  • 粉丝2
  • 关注0
  • 发帖57
  • 主页
  • 金币285枚
Ifyou 发布于2017-06-29 16:36
0/250

App的网络环境测试和性能问题

楼层直达

从测试的角度,应该建立实时监控的web portal。其实测试的目的除了保证产品发布的质量。更重要的是为优化提供依据,所以report最后一部分都是issue list optmize advice,当然测试最难的部分也是优化
 
移动网络和传统网络另一个很大的区别是Connection Migration问题。定义一个Socket连接是四元组(客户端IP,客户端Port,服务端IP,服务端Port),当用户的网络在WIFI/4G/3G/2G类型中切换时,其客户端IP会发生变化,如果此时正在进行网络服务通讯,那么Socket连接自身已经失效,最终也会导致网络服务失败。
 
常见的网络性能问题有如下几种:
 
问题一:DNS问题
 
DNS出问题的概率其实比大家感觉的要大,首先是DNS被劫持或者失效,2015年初业内比较知名的就有Apple内部DNS问题导致App StoreiTunes
Connect账户无法登录;京东因为CDN域名付费问题导致服务停摆。携程在去年11月也遇到过DNS问题,主域名被国外服务商误列入黑名单,导致主站和H5等所有站点无法访问,但是App客户端的Native服务都正常,原因后面介绍。
 
另一个常见问题就是DNS解析慢或者失败,例如国内中国运营商网络的DNS就很慢,一次DNS查询的耗时甚至都能赶上一次连接的耗时,尤其2G网络情况下,DNS解析失败是很常见的。因此如果直接使用DNS,对于首次网络服务请求耗时和整体服务成功率都有非常大的影响。
 
问题二:TCP连接问题
 
DNS成功后拿到IP,便可以发起TCP连接。HTTP协议的网络层也是TCP连接,因此TCP连接的成功和耗时也成为网络性能的一个因素。我们发现常见的问题有TCP端口被封(例如上海长宽对非HTTP常见端口808080443的封锁),以及TCP连接超时时长问题。端口被封,直接导致无法连接;连接超时时长过短,在低速网络上可能总是无法连接成果;连接超时过长,又有可能导致用户长时间等待,用户体验差。很多时候尽快失败重新发起一次连接会很快,这也是移动网络带宽不稳定情况下的一个常见情况。
 
问题三:Write/Read问题
 
DNS LookupTCP连接成功后,就会开始发送Request,服务端处理后返回Response,如果是HTTP连接,业内大部分App是使用第三方SDK或者系统提供的API来实现,那么只能设置些缓存策略和超时时间。iOS上的NSURLConnection超时时间在不同版本上还有不同的定义,很多时候需要自己设置Timer来实现;如果是直接使用TCP连接实现网络服务,就要自己对读写超时时间负责,与网络连接超时时长参数类似,太小了在低速网络很容易读写失败,太大了又可能影响用户体验,因此需要非常小心地处理。
 
我们还遇到另一类问题,某些酒店Wi-Fi对使用非808080443等常见HTTP端口的服务进行了限制,即使发送Request是正常的,服务端能够正常收到,但是Response却被酒店网络proxy或防火墙拦截,客户端最终会等待读取超时。
 
问题四:传输Payload过大
 
传的多就传的慢,如果没做过特别优化,传输Payload可能会比实际所需要的大很多,那么对于整体网络服务耗时影响非常大。
 
问题五:复杂的国内外网络情况
 
国内运营商互联和海外访问国内带宽低传输慢的问题也令人难非常头疼。
 
TestBird

0人打赏
您需要登录后才可以回帖
发表回复
极贡献
技术问答
专题荟萃
程序人生
视觉设计
Android开发
iOS开发
编程语言
前端开发
后端开发
服务器架构
软件测试
运维方案
创业路上



最热文章墙

  • 79416/378   【精品推荐】200多种Android动画效果的强悍框架,太全了,不看这个,再有动画的问题,不理你了^@^

  • 45307/191   情人节福利,程序员表白的正确姿势:改几行代码就变成自己的表白了

  • 44993/0   Python爬虫:常用浏览器的useragent

  • 41475/260   【精品推荐】Android版产品级的音乐播放器源码,功能太强大了,最好的产品原型有木有?

  • 38687/145   省时省力的Android组件群来了,非常棒的原型参考

  • 30063/142   2016抢红包软件及源码

  • 29299/2   超全!整理常用的iOS第三方资源

  • 29290/71   原创表白APP,以程序员的姿势备战新年后的7夕,持续完善中!

  • 24355/160   Android版类似UC浏览器:非常赞,产品级的源码

  • 22870/30   麻省理工的一帮疯子,真的实现了随意操控万物!(绝对黑科技)

  • 22568/25   Android工程师面试题大全

  • 22494/27   2016程序员跳槽全攻略

  • 21954/9   GitHub上排名前50的iOS项目:总有一款你用得着

  • 20912/20   码魂:程序员的牛B漫画

  • 19065/85   Android小而全的博客源码:非常适合全面掌握开发技巧

  • 19055/73   【持续更新中】Android福利贴(二):资料源码大放送

  • 19019/10   2016年最全的Android面试考题+答案 精编版

  • 18922/42   一个绚丽的loading动效分析与实现!

  • 18765/3   吐槽那些程序员的搞笑牛逼注释

  • 17642/45   惊艳的App引导页:背景图片切换加各个页面动画效果

  • 17633/1   iOS 动画总结

  • 17511/82   仿京东商城客户端Android最新版,不错的原型和学习资料

  • 17472/104   Android带弹幕的视频播放器源码,来自大名鼎鼎的Bilibili弹幕网站

  • 17150/23   个人收集的Android 各类功能源代码

  • 16692/5   新一代Android渠道打包工具:1000个渠道包只需要5秒

  • 16619/21   Android福利第三波【Android电子书】

  • 16438/53   基于瀑布流的美女图片浏览App,有注释的源代码

  • 16419/81   【精品推荐】类似360安全卫士安Android源码:非常赞的产品原型

  • 16406/10   女程序员的梦,众网友的神回复

  • 16367/0   iOS中文版资源库,非常全

  • 16342/17   用JavaScript 来开发iOS和Android 原生应用:React Native开源框架中文版来啦

  • 16096/11   年会上现场review代码是怎么样的体验!

  • 16042/23   珍藏多年的素材,灵感搜寻网站

  • 15525/18   65条最常用正则表达式,你要的都在这里了

  • 14853/15   基于Android支付宝支付设计和开发方案

  • 14259/11   有木有这样一张酷图帮你集齐所有git命令超实用

  • 14190/17   什么是真正的黑客:收获12200+Stars,人气远超微软开源VS

  • 13970/46   在线音乐播放器完整版(商用级的源码):非常赞,可听免费高品质专辑

  • 13719/0   GitHub iOS 库和框架Top100 

  • 13675/61   【技巧一】搭配Android Studio,如何实现App远程真机debug?

  • 13570/7   用程序员的姿势抢过年的火车票

  • 13523/7   一张图搞定iOS学习路线,非常全面

  • 13152/10   成为Java顶尖程序员 ,看这11本书就够了

  • 13110/10   微信支付终于成功了(安卓,iOS),在此分享

  • 12999/18   一张图搞定Android学习路线,非常全面

  • 12811/29   【持续更新中】Android福利贴(一):资料源码

  • 12747/3   基于Node.js的强大爬虫,能直接发布抓取的文章哦

  • 12491/4   46 个非常有用的 PHP 代码片段

  • 12014/3   即时通信第三方库

  • 11452/8   流媒体视频直播方案

  • 11385/18   八个最优秀的Android Studio插件

  • 11256/9   B站建开源工作组:APP想支持炫酷弹幕的看过来

  • 11048/9   烧了5亿美金,这家神秘的公司即将颠覆人类未来!

  • 11033/2   【精品推荐】高质量PHP代码的50个实用技巧:非常值得收藏

  • 10952/10   中国黑客的隐秘江湖:攻守对立,顶尖高手月入千万美元

  • 10228/6   开箱即用!Android四款系统架构工具

  • 10017/10   十大技巧快速提升Android应用开发性能

  • 9975/3   10款GitHub上最火爆的国产开源项目——可以媲美西半球

  • 9922/1   Android性能优化视频,文档以及工具

  • 9810/0   基于node-webkit跨平台应用案例集之(一)

  • 返回顶部