移动网络下的性能优化之网络篇

作者:王军鹏
野狗iOS资深工程师,国内第一批iOS开发者,曾在人人担任高级工程师。多年逆向工程开发经验,对iOS系统底层有深入了解。

野狗官博:https://blog.wilddog.com/
野狗官网:https://www.wilddog.com/
公众订阅号:wilddogbaas

图片描述

上篇文章我们分析了移动网络耗电较高的原因,并给出了相应的解决方案。本篇文章我们将分析移动网络延迟较高的原因,并给出相应的优化方案。

移动网络延迟高的原因

唤醒延迟

在移动网络下,手机要接入网络,必须先向控制平台发送申请。只有当控制平台将手机切换到Active状态,手机才能进行通信,这一过程在3G网络下消耗的时间一般在500-2500ms之间,我们称之为唤醒延迟。这是一个造成移动网络延迟的原因。

HTTP延迟

在APP开发中,我们会经常用到HTTP协议,HTTP延迟就是在使用这个协议时产生的。

图片描述

pasted-image一个HTTP请求从客户端发送到服务端的过程中,需要进行域名查询,这时客户端就会发起一个DNS Query。这个过程所需的时间和ISP(互联网服务供应商)、请求页面知名度、是否存在缓存以及服务器的响应时间都有关系。客户端在拿到解析出的IP后,还要经过我们熟知的TCP三次握手,这个过程需要耗时几百毫秒,甚至可能达到几秒。TCP握手完成后,还需发送HTTP请求传递我们的参数,取得服务器返回的数据。如果是HTTPS协议的话还需要进行TLS握手,这就又要增加两轮的延迟等待。

所有的这些都需要消耗时间,再加上RRC控制平台唤醒手机到Active状态所要消耗的时间,形成以下3G网络和4G网络的对比图。

图片描述

从表中我们可以看到:在没有计算服务器反应时间的情况下,3G网络下一条HTTP请求需要600-3500ms,4G网络下大概也需要0.5s。

核心网络延迟

下图是在移动网络下,一个手机向服务器传输数据的完整过程。

图片描述

首先,手机需要切换到Active状态才能正常通信。手机向无线接入网络发送一条通信请求,无线接入网络收到后,给手机分配通信资源。这一步骤在3G网络最多需要花费2s,手机切换到Active状态后,开始向无线接入网络传输数据,基站无线接入网络收到后把数据发送给服务网关,服务网关将数据传给数据网关,数据网关再传输给服务器。

我们再看看服务器收到数据后给手机返回数据的通信过程,如图所示:

图片描述

服务器将数据传给数据网关,数据网关把数据交给服务网关,这时服务网关并不知道这设备在哪,只有把这个任务交给无线接入网络,无线接入网络找到设备后将手机切换到Active状态准备接受数据,然后告诉服务网关可以发送数据了,服务网关收到指令后将数据交给无线接入网络,无线接入网络再将数据发给手机。这样一次通信才算是最终完成。

我们只想完成一次请求,而在这传输过程中我们却不得不忍受各种各样的延迟,包括路由选择延迟、唤醒延迟、控制平台延迟、骨干网络延迟、用户平台延迟等。

如何降低延迟

提前唤醒

如果对速度要求很高,我们可以提前唤醒手机,并使其一直处于唤醒状态,当然这是以损耗电池为代价的。另外从用户体验上来说,对于超过2s的请求都应该给一个进度状态。

数据缓存

最快的请求就是不请求。网络通信的延迟是不可以避免的,但是对于已经请求过的数据请务必缓存下来,在下次再次访问时直接从本地获取。这样不仅能让用户有更流畅的操作,即使是在断网的情况下也能使用APP。

压缩资源

GZIP压缩资源。GZIP压缩一般对纯文本内容可压缩到原大小的40%,这样可以有效减少服务器带宽占用,提高我们我们的请求速度。

使用WebP图片格式

使用合适的图片格式。一般图片资源至少占整个APP数据量的50%以上,所以压缩图片大小对提高性能也是非常重要的。这里推荐使用WebP图片格式,在质量相同的情况下,WebP格式图片的体积要比JPEG格式图片小40%。

使用不同策略

现在2G,3G,4G网络并存,网络速度差距也很大,针对每种网络应该有不同的应对策略。比如2G网络不自动打开图片,3G,4G网络询问是否播放视频等。

使用CDN

在全国各地多布设CDN加速节点,特别是网络流量比较大的区域,也能有效缓解核心网络所带来的延迟。


野狗科技官方专栏
野狗丨安全可靠的实时通信云 野狗为开发者提供实时通信服务。可应用于IM聊天、在线协作、实时游戏、实时...

野狗|安全可靠的实时通信云

2.3k 声望
116 粉丝
0 条评论
推荐阅读
轻松给小程序注入实时体验 | 野狗 SDK (微信小程序版) 正式发布
如果你的应用场景需要实时性,那么野狗能提供毫秒级的实时通信(例如 QQ 和微信这类及时通讯应用,当然这只是一个方面)和数据分发功能(类似于股票行情信息的实时推送)。

野狗阅读 6.7k评论 1

网易云音乐开源全链路埋点方案-曙光埋点(dawn)
网易云音乐开源了曙光埋点 dawn,一个跨多端的全链路埋点解决方案,旨在构造一个完美的数据理想国。曙光埋点创造性的提出了埋点虚拟树(VTree),并在此基础上实现了诸多能力,解决大前端侧埋点困难、精度差、不...

云音乐技术团队3阅读 2.5k

封面图
深度剖析 Runtime
做很多需求或者是技术细节验证的时候会用到 Runtime 技术,用了挺久的了,本文就写一些场景和源码分析相关的文章。先问几个小问题:class_rw_t的结构是数组,数组里面的元素是数组,那它是二维数组吗?为什么16字...

杭城小刘4阅读 1.3k

封面图
“老默我想吃鱼了”与五层网络模型
最近看狂飙有点上头了😂,还专门把几百人的群昵称改成了“摸鱼强盛集团”,群友们也很积极,昵称都改成了狂飙中的人名,聊着聊着嘴里蹦出几句狂飙中的台词,一时间感觉还蛮有意思的,群里充满了欢心笑语,给疲惫了一...

法医3阅读 1k

封面图
Tomcat处理http请求之源码分析 | 京东云技术团队
在上面的代码中,socket = serverSocketFactory.acceptSocket(serverSocket);与客户端建立连接,将连接的socket交给processSocket(socket)来处理。在processSocket中,对socket进行包装一下交给线程池来处理:

京东云开发者2阅读 276

封面图
Apache 中 ServerTokens 参数设置详解
ServerTokens 参数设置 http 头部返回的 apache 版本信息,可用的值和含义如下:ServerTokens 参数值意义ServerTokens Prod仅软件名称例如:apacheServerTokens Major包括主版本号例如:apache/2ServerTokens Min...

danielxue7阅读 3.5k

「Go 框架」bind 函数:gin 框架中是如何绑定请求数据的?
在gin框架中,我们知道用bind函数(或bindXXX函数)能够将请求体中的参数绑定到对应的结构体上。同时,你也会发现在gin中有很多bind或bindXXX函数,比如ShouldBind、ShouldBindQuery、ShouldBindHeader、ShouldBi...

Go学堂1阅读 1.3k

封面图

野狗|安全可靠的实时通信云

2.3k 声望
116 粉丝
宣传栏