阿里云服务器免费领卷啦。

捡代码论坛-最全的游戏源码下载技术网站!

 找回密码
 立 即 注 册

QQ登录

只需一步,快速开始

搜索
关于源码区的附件失效或欺骗帖, 处理办法
查看: 2600|回复: 0

友盟自动更新技术解决方案(安卓版)

[复制链接]

4213

主题

210

回帖

12万

积分

管理员

管理员

Rank: 9Rank: 9Rank: 9

积分
127206
QQ
发表于 2016-6-22 12:42:53 | 显示全部楼层 |阅读模式
系统结构
友盟自动更新系统的示意图如下:
112616y3ff2y8w22l32kh8.jpg

图中手机代表客户端。服务端的各个模块描述如下:

  • WebConsole:提供上传更新包的网站操作界面。
  • FS:文件系统,存储apk文件和增量更新包,增量更新的原理后文会提到。
  • DB:用于存储文件的属性,例如版本号,更新描述,文件的md5等。
  • Server: 接收客户端请求,返回文件下载链接。
  • CDN:提供文件下载服务(友盟用到的是阿里云的CDN服务)。


基本流程
1 用户在WebConsole上传更新包、填写更新版本和更新日志,程序将更新包存储到FS,版本(version-code)、更新日志、文件md5及其他配置信息存储到DB。
2 客户端请求Server,传入客户端的appkey、版本号、md5等信息。Server与DB存储的信息比较,如果需要更新则返回更新包的url,否则返回不更新。
3 客户端收到服务器端的返回结果后判断是否需要更新,如果需要更新,则弹窗提示用户有新版本更新,用户确认后下载安装包,安装新版本。

交互协议(示例)
客户端和Server之间使用https接口通信。使用POST请求方式,交互的信息都在http的content中,格式为json。以下简单示例协议中的关键字段。

Request:
  1. {
  2. "appkey":"xxxxxxxxxx",
  3. "version_code":1,
  4. "old_md5":"xxxxxxxxxxxxxxxxx"
  5. }
复制代码
其中version_code是客户端软件的版本号,old_md5是客户端apk文件的md5值。

Response:
如果不需要更新则返回下面的response
  1. {
  2. "update": "No"
  3. }
复制代码

如果需要更新, 则返回下面的reponse:
  1. // 全量更新
  2. {
  3. "update":"Yes",
  4. "new_version":"xxxxx",
  5. "apk_url":"http://cdn.the.url.of.apk/or/patch", // CDN链接下载地址
  6. "update_log":"xxxx",  // 更新日志,用于在界面上显示
  7. "delta":false,
  8. "new_md5":"xxxxxxxxxxxxxx",
  9. "target_size":"601132"
  10. }[/p][p=21, null, left]
复制代码
  1. // 增量更新
  2. {
  3. "update":"Yes",
  4. "new_version":"xxxxx",
  5. "apk_url":"http://cdn.the.url.of.apk/or/patch", // CDN链接下载地址
  6. "update_log":"xxxx",  // 更新日志,用于在界面上显示",
  7. "delta":true,
  8. "new_md5":"xxxxxxxxxxxxxx", // full-apk的md5
  9. "target_size":"601132", // full-apk的size
  10. "patch_md5":"xxxxxxxxxxxxxxxxx", // patch文件的size
  11. "size":"337852" // patch文件的md5
  12. }
复制代码

服务端处理流程
流程图如下:
112616cdeqg8gbs4wgwtbr.png
1. 客户端发送请求至服务端,请求内容除了必要的验证信息以外,最重要的信息就是version_code,或者类似的用于比较版本号以判断是否需要升级的字段信息。
2. 服务端接收到请求后,验证请求的有效性。
3. 若请求有效,则对比请求中的version_code是否是最新的。
4. 若不是最新的version_code,则说明需要进行更新,此时需要首先判断是否能够进行增量更新。如果请求中version_code对应的apk文件在服务端存在且md5一致,则可以进行增量更新,否则不能。
5 如果不能增量更新,则直接返回apk文件的CDN下载链接。
6 如果能进行增量更新,首先判断对应的patch文件是否存在,如果不存在则调用bsdiff命令生成patch文件后返回patch文件的CDN链接;如果存在就直接返回patch文件CDN链接。

客户端处理流程
1.客户端首先请求server,获得是否有新版本的更新信息。
2. 如果没有更新,则客户端不进行更新动作。
3. 如果服务端返回的是有更新,客户端会根据全量更新和增量更新两种情况来处理:  如果服务器端返回的是全量更新,则会开启service下载完整版的apk文件; 如果服务器端返回的是增量更新,则会开启service下载patch文件到本地,然后使用JNI进行bspatch,给原apk文件打补丁,生成新版本的apk文件,生成的apk文件要进行MD5校验,如果与后台上传的apk文件的MD5值相等,则认为bspatch成功。
更新对话框如下:
112616uyleeknlcknnevky.png

4. 客户端在下载完成后,会提示安装,若用户忽略,则会在下次检测更新的时候,首先判断本地是否已经存在最新版的apk文件,若已存在,则会提示安装。

一些经验
0. 客户端与服务器端之间的数据传输要进行加密处理,推荐使用https协议。
1. 建议使用全量更新,目前已知增量更新方案在部分系统厂商上不能正常工作。
2. 当遇到apk有较大改动时,可能会出现差分包和新apk大小相差不大的情况。这种情况下,建议进行全量升级。因为合并差分包的耗费的时间可能会超过全量升级所花费的时间。
3. 当apk本身较小时,全量更新更加合适
4. 若系统内置的apk文件无法获取到,则无法进行增量更新(bspatch是根据系统内置的apk文件与patch文件来合并生成新版本的apk文件)。
5. 为防止增量更新合成的apk文件有误,需要对合成的apk文件和最新版的apk文件进行MD5校验。

What's more
渠道更新
在本文描述的处理流程基础上,增加很少的扩展就可以实现分渠道更新。具体的做法是:
1 在上传安装文件时分不同渠道存储,相应的DB里面存储的时候也增加channel的字段。
2 客户端请求中增加一个字段channel,用于标识客户端的渠道。
3 服务端根据不同的渠道返回不同的下载链接。



原始链接:http://bbs.umeng.com/thread-15012-1-1.html

捡代码论坛-最全的游戏源码下载技术网站! - 论坛版权郑重声明:
1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
2、本站所有主题由该帖子作者发表,该帖子作者与捡代码论坛-最全的游戏源码下载技术网站!享有帖子相关版权
3、捡代码论坛版权,详细了解请点击。
4、本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,不存在任何商业目的与商业用途。
5、若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。 我们不承担任何技术及版权问题,且不对任何资源负法律责任。
6、如无法链接失效或侵犯版权,请给我们来信:jiandaima@foxmail.com

回复

使用道具 举报

*滑块验证:
您需要登录后才可以回帖 登录 | 立 即 注 册

本版积分规则

技术支持
在线咨询
QQ咨询
3351529868

QQ|手机版|小黑屋|捡代码论坛-专业源码分享下载 ( 陕ICP备15015195号-1|网站地图

GMT+8, 2025-1-22 23:40

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表