android上传下载系列:如何优化上传的性能

更新时间:2023-07-05 05:36:44 阅读: 评论:0

android上传下载系列:如何优化上传的性能
转载⾃以下⽂章:
如何优化⽂件上传性能?
对于⽂件上传性能优化,可以从两个⽅⾯来着⼿,即上传前的优化和上传过程中的优化。
经典黑色幽默电影#⼀.上传前的优化
主要有两个思路。
思路⼀:通过减少⽂件体积,减少上传流量来优化。
思路⼆:通过合并⼩⽂件,减少请求数来优化。
基于这两个思路,我们尝试了以下⼏种⽅案。
##1.图⽚压缩
如果上传的是图⽚类⽂件,存在⼀部分⽤户喜欢直接选择相机或者⼿机拍摄的原始⽂件进⾏上传,对于
这类图⽚,图⽚的分辨极⾼,⾼达5000多。这就注定了此图⽚的⽂件体积不会太⼩。其实如果只是在电脑上查看,1千多的分辨率就已经⾜够。于是我们尝试通过js将此类图⽚进⾏缩⼩,得出的结果是:1张(5184×3456)⼤⼩为5M的jpg图⽚,缩⼩到(1600x1600)后,体积变成了407kb, 直接节省了
4.5M的流量。
##2.ZIP 合并⼩⽂件
类似于拷贝⽂件夹到U盘,如果⼩⽂件⽐较多,拷贝过程⾮常慢,通常我们的做法是将⽂件夹打包成⼀个⽂件再拷贝,速度往往要快出许多。其实⽂件上传也⼀样,如果能把体积⽐较⼩的⽂件合并成⼀个⽂件,请求数就会少了很多,这样是不是就提⾼了整体⽂件上传速度呢?
但是,通过测试得出的结果是不尽如意的。ZIP的运算效率太低,以⾄于只有在2G⽹络下才有速度提升,3G和wifi⽹络下反⽽变慢了。更多细节请移步到这⾥。
##3.SPRITE 合并⼩图⽚
类似于css sprite, 将多个⼩图⽚画到⼀张⼤图⽚上,通过这种⽅式来进⾏合并,思路和zip合并差不多,但是采⽤的技术不太⼀样,此⽅案是直接⽤canvas来画,经过测试发现速度⽐zip快出来10倍,总体能带来20%左右的速度提升。
但是此⽅案只满⾜于图⽚类⽂件,且服务端需要通过位置信息还原出⼩⽂件,带来⼀定的服务端开发成本,⽬前并没有采⽤此⽅案。更多细节请移步到这⾥。
##4.直接合并⽂件内容
其实,并不需要采⽤ZIP或者SPRIT⽅式合并⽂件,把⽂件读取出 arraybuffer 后是直接可以连接在⼀起的,之后还可以再次转成 blob 发送到服务端,或者直接发送 arraybuffer,理论上性能应该⽐SPRITE⽅案靠谱。
但是这块没有进⾏详细的调研,在此就不多说了。
#⼆.上传过程中优化
主要采⽤并发与分块,以下将细说这两个⽅案。
##1.并发上传
采⽤此⽅案主要是源于单⼀请求⽆法让⽹络达到饱和,于是我们来尝试采⽤并发⽅式看能否提⾼总体⽂件上传速度。
四级满分多少>保卫婚姻战以下是通过测试20个1M的⽂件在不同的并发数下得到的总体上传时间对⽐图。
很明显,并发数越多速度越快!
但是,并发数越多,给服务端带来的压⼒也越⼤,如何去选择⼀个合适的并发数呢?
主要可以从三⽅⾯去考虑。
并发数越多,服务端压⼒越⼤,所以选择并发数不能太⼤!
同时每个浏览器都有固定的最⼤并发数限制,所以选择并发数不能超出这个值。
从上⾯的图标可以看出,并发数到了3以后,收益开始渐渐不明显。
如是,最佳的并发数应该是3。
##2.分块上传
为什么要采⽤分块上传?
混淆英文
试想⼀下,如果上传的⽂件是⼀个⼤⽂件,本来上传时间就相对较久,再加上⽹络不稳定各种因素影响,容易导致传输中断,⽤户除了重传整个⽂件外没有更好的选择。采⽤分⽚上传可以很好地解决这个问题。
什么是分⽚上传?
分块上传,就是把⼀个⼤的⽂件分成若⼲块,⼀块⼀块的传输。如上⾯的ca, 如果传输中断,仅需重传出错的分⽚,⽽不需要重传整个⽂件,⼤⼤减少了重传开销。
那么,采⽤分块上传还有哪些优势?
1.更强容错能⼒
如以上的ca, 出错重传,仅需重传⼀⼩块。
2.可以模拟暂停与继续
对于⼀个http请求,其实并没有暂停功能,要不就是已完成,要不就是已中断。如果不分块,是没法做暂停功能。但是如果采⽤分块上传,在某个分块上传完了后不⾃动开始下个分块上传,是不是就实现了暂停功能?
利⽤此功能,就可以通过⽹络检测,在⽹络断开的时候⾃动暂停传输,⽹络恢复后,继续传输,给⽤户带来更好的体验效果。
3.利⽤并发提速
如果单独的上传⼀个⼤⽂件,只有采⽤了分块上传才能利⽤并发请求来提速。
4.更精准的速度跟踪
关于客户端监控上传进度,其实监控的都是客户端的发送速度,服务端有没有接收,有没有存储,是不知道的,只有在整个请求完毕,收到服务端反馈后才能确定数据已经成功接收。这样也就解释了进度显⽰的时候,长长出现,进度条瞬间到100%,要过⼀段时间才全部完成。如果采⽤分块上传,每个分块上传完成,可以确定这个分块服务端已经成功接收。
当然,分块也会有⼀定的副作⽤,本来是⼀个请求,分块后变成了多个请求,⾃然会带来⽹络开销。那么具体是个什么的情况呢?
以下是通过测试3个30M的⽂件在3个并发下调整不同的分⽚⼤⼩得出的总体时间消耗表。
那么,如何选择⼀个合适的分块⼤⼩?
主要有三个⽅⾯的考虑。
分块越⼩,请求越多,开销越⼤。所以不能设置得太⼩。
分块越⼤,灵活度越⼩,前⾯所说的那些优势就会相对越不明显。故不能太⼩。
诚信演讲稿服务端⼀般都会有个固定⼤⼩的接受buffer(clientbodybuffer_size), 分块的⼤⼩最好是这个值的整数倍。
综合这些考虑,推荐的分块⼤⼩是2M-5M,具体size根据产品中⽂件上传的⼤⼩分布来定。如果上传的⽂件⼤部分是500M以上,很⼤的⽂件,建议是5M, 如果相对较⼩,推荐2M。
##3.断点续传
有了分块上传,其实我们可以实现更多的功能。试想,如果服务端能够把每个已成功上传的分块都记住,客户端可以快速验证,条件选择跳过某个分块,是不是就实现了断点续传?
那么,断点续传能带来哪些好处?
节省流量,避免上传重复的分块。
减少⽤户等待时间。
可恢复的上传。出现中断,就算浏览器刷新或者是换了台电脑也能恢复到上次中断的位置。
kuyu
那么现在最关键的问题是如何标识⼀个分块了。怎样标识让服务端好⼊库,同时客户端可以快速的计算出来与服务端验证,换句话说就是,如何去找出分块的唯⼀ID。
之前尝试过⽂件名+分块编号,或者再加⽂件⼤⼩,⽂件最后修改时间什么的,都⽆法保证分块的唯⼀性。于是还是直接采⽤ MD5 的⽅式来序列化⽂件内容吧,这样就算是⽂件不同名,只要内容是⼀致的也会正确地识别出是同⼀个分块。
那么现在的逻辑就是,每次分块上传前,根据内容 MD5 序列化,得到⼀个唯⼀ID,与服务端验证,如果此分块已经存在于服务端,则直接跳过此分块上传,否则上传此分块,成功后,服务端记下此分块ID。
如是,分块上传是不是具有了秒传的功能?既然分块能秒传,那么整个⽂件是否也可以秒传?
##4.秒传
分块能秒传,整个⽂件当然也能秒传,关键还是看 MD5 的性能。
通过以上测试结果可以看出,如果⽂件⼤⼩在 10M 以内,是可以真正的秒级内完成的,⼤于这个值时间花费就⼤于1秒了,⽐如⼀个
angel的意思200M的⽂件 MD5 时间花费需要13秒左右。
但是,即便如此,相⽐于⽂件传输时间花费,MD5 的时间花费根本就不算什么。对于类似于百度云,
⽂库这类的产品,在上传⼀个⽂件的时候很可能服务端已经存在了此⽂件,如果多等个⼏秒钟,能跳过整个⽂件上传,我觉得是⾮常划算的。
拖福
##5.算法优化
另外,如果是⼀次上传多个⽂件是可以在算法上去优化这个过程的。
早春呈水部张十八员外古诗的意思翻译
1.验证过程提前到当前⽂件的传输期2009年英语四级成绩查询
如果当前⽂件已经在传输了,这个时候,⽤户是处于等待状态,机器也处于等待期,如果把下⼀个⽂件的验证过程移⾄此过程,那么⽤户的等待 MD5 的时间和等待当前⽂件传输完成的时间就重合了。这样⽤户就只需要等待第⼀个⽂件的验证过程。
2.⼩⽂件优先处理,减少⽤户等待时间
因为第⼀个⽂件的验证等待⽆法避免,如果第⼀个⽂件处理的⽂件越⼩,是不是等待的时间就越短?所以把队列中最⼩的⼀个⽂件放到第⼀个优先处理可以进⼀步减少⽤户等待时间
3.更换序列化算法,取段MD5
其实对于某些⼆进制⽂件,如JPEG,前⾯⼀段数据记录了很多此图⽚的信息,⽐如:拍摄时间,相机名称,图⽚尺⼨,图⽚旋转度等等,直接 MD5 这⼀段数据基本上就可以保证此⽂件的唯⼀性了。只要取段的总⼤⼩⼩于10M,再⼤的⽂件也能在1秒内完成序列号⼯作。

本文发布于:2023-07-05 05:36:44,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/90/167521.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:上传   分块   服务端   时间
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图