文档章节

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

Skqing
 Skqing
发布于 2016/05/16 17:15
字数 1541
阅读 27
收藏 0
点赞 2
评论 0

系统结构 友盟自动更新系统的示意图如下: 示意图

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

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: [Java] 纯文本查看 复制代码 ? 1 2 3 4 5 { "appkey":"xxxxxxxxxx", "version_code":1, "old_md5":"xxxxxxxxxxxxxxxxx" } 其中version_code是客户端软件的版本号,old_md5是客户端apk文件的md5值。

Response: 如果不需要更新则返回下面的response [Java] 纯文本查看 复制代码 ? 1 2 3 { "update": "No" }

如果需要更新, 则返回下面的reponse: [Java] 纯文本查看 复制代码 ? 01 02 03 04 05 06 07 08 09 10 // 全量更新 { "update":"Yes", "new_version":"xxxxx", "apk_url":"http://cdn.the.url.of.apk/or/patch", // CDN链接下载地址 "update_log":"xxxx", // 更新日志,用于在界面上显示 "delta":false, "new_md5":"xxxxxxxxxxxxxx", "target_size":"601132" }[/p][p=21, null, left] [Java] 纯文本查看 复制代码 ? 01 02 03 04 05 06 07 08 09 10 11 12 // 增量更新 { "update":"Yes", "new_version":"xxxxx", "apk_url":"http://cdn.the.url.of.apk/or/patch", // CDN链接下载地址 "update_log":"xxxx", // 更新日志,用于在界面上显示", "delta":true, "new_md5":"xxxxxxxxxxxxxx", // full-apk的md5 "target_size":"601132", // full-apk的size "patch_md5":"xxxxxxxxxxxxxxxxx", // patch文件的size "size":"337852" // patch文件的md5 }

服务端处理流程 流程图如下: 流程图

  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成功。 更新对话框如下: 对话框 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 服务端根据不同的渠道返回不同的下载链接。

iOS自动更新 参见http://bbs.umeng.com/thread-11135-1-1.html

参考资料 bsdiff & bspatch:http://www.daemonology.net/bsdiff/

本文转载自:http://bbs.umeng.com/thread-15012-1-1.html

共有 人打赏支持
Skqing

Skqing

粉丝 33
博文 141
码字总数 20130
作品 0
深圳
后端工程师
Android使用友盟集成QQ、微信、微博等第三方登录

前言 最近项目需要加入第三方分享和登录功能,之前其他项目的第三方分享和登录一直都使用ShareSDK实现的。为了统一使用友盟的全家桶,所以三方分享和登录也就选择了友盟。这里记录一下完整的...

慕前端7069444 ⋅ 05/21 ⋅ 0

Android项目实战(三十五):多渠道打包

   多渠道打包:   可以理解为:同时发布多个渠道的apk。分别上架不同的应用商店。这些apk带有各自渠道的标签,用于统计分析各个商店的下载次数等数据。   实现步骤   一、添加友盟渠...

听着music睡 ⋅ 2017/09/25 ⋅ 0

腾讯技术分享:Android版手机QQ的缓存监控与优化实践

本文内容整理自公众号腾讯Bugly,感谢原作者的分享。 1、问题背景 对于Android应用来说,内存向来是比较重要的性能指标。内存占用过高,会影响应用的流畅度,甚至引发OOM,非常影响用户体验。...

JackJiang2011 ⋅ 04/08 ⋅ 0

Android P 版本号为 9,第三个开发者预览版有这些变化

近日,Google 如期放出了 Android P 的第三个开发者预览版(以下简称 DP3)。DP3 主要面向应用开发者,将该版本操作系统的 API 等级正式确定为 API level 28,开发者可以借助相关的 SDK 面向...

h4cd ⋅ 06/10 ⋅ 0

AndroidThings之基础一 基本概念

转载自:https://blog.csdn.net/weixin41636248/article/details/79069994 Android Things是什么 一句话说,AndroidThings就是让开发者可以使用Android开发工具开发嵌入式设备。 If you can...

qq_28831197 ⋅ 05/09 ⋅ 0

Android Studio 3.2 Canary 发布,新增大量实用功能

在今天的 Google 2018 I/O 大会上,释出了 Android Studio 3.2 的最新预览版,并带来了一系列的新功能,如支持 Android P 开发预览版、新的 Android App Bundle,以及 Android Jetpack。官方...

局长 ⋅ 05/09 ⋅ 0

谷歌I/O大会8大看点:有Android系统全面更新

谷歌I/O大会8大看点:有Android系统全面更新 2018-05-08 10:27编辑: 枣泥布丁分类:业界动态来源:cnBate Android谷歌I/O大会 招聘信息: C++工程师 Cocos2d-x游戏客户端开发 iOS开发工程师...

枣泥布丁 ⋅ 05/08 ⋅ 0

【开源访谈】全面解读 Airtest,Google 青睐的开源自动化测试方案

游戏应用更新频繁,如何在发布更新之前快速将 bug 找出来并修复,以免延误版本发布,这对游戏的测试来说是一大挑战。游戏自动化测试方案的出现减轻了测试人员的负担,同时提高了上游开发与设...

雨田桑 ⋅ 04/25 ⋅ 0

Android Studio 3.1.2 bug 修复版发布,改进 lint 审查

Android Studio 3.1.2 bug 修复版已发布,本次更新修复了一些错误,并改进了某些场景下 lint 审查的速度。详细的修复内容请查看 Android Studio 3.1.2 的发布说明。 此外,Android Studio 3....

局长 ⋅ 04/24 ⋅ 1

Java转iOS-第一个项目总结(1)

0.前言 本人14年12月份,从网站开发组转到了移动开发组,自己的java两年半工作经验变成了objective-c零经验。2015年1月份新启动了一个移动项目,年后因为人事变动,自己从辅助开发变成了"核心...

蛙牛 ⋅ 2015/03/31 ⋅ 67

没有更多内容

加载失败,请刷新页面

加载更多

下一页

来自一个优秀Java工程师的简历

写在前面: 鉴于前几天的一份前端简历,虽然带着很多不看好的声音,但却帮助了很多正在求职路上的人,不管评论怎么说,我还是决定要贴出一份后端的简历。 XXX ID:357912485 目前正在找工作 ...

颖伙虫 ⋅ 20分钟前 ⋅ 0

Confluence 6 恢复一个站点有关使用站点导出为备份的说明

推荐使用生产备份策略。我们推荐你针对你的生产环境中使用的 Confluence 参考 Production Backup Strategy 页面中的内容进行备份和恢复(这个需要你备份你的数据库和 home 目录)。XML 导出备...

honeymose ⋅ 今天 ⋅ 0

JavaScript零基础入门——(九)JavaScript的函数

JavaScript零基础入门——(九)JavaScript的函数 欢迎回到我们的JavaScript零基础入门,上一节课我们了解了有关JS中数组的相关知识点,不知道大家有没有自己去敲一敲,消化一下?这一节课,...

JandenMa ⋅ 今天 ⋅ 0

火狐浏览器各版本下载及插件httprequest

各版本下载地址:http://ftp.mozilla.org/pub/mozilla.org//firefox/releases/ httprequest插件截至57版本可用

xiaoge2016 ⋅ 今天 ⋅ 0

Docker系列教程28-实战:使用Docker Compose运行ELK

原文:http://www.itmuch.com/docker/28-docker-compose-in-action-elk/,转载请说明出处。 ElasticSearch【存储】 Logtash【日志聚合器】 Kibana【界面】 答案: version: '2'services: ...

周立_ITMuch ⋅ 今天 ⋅ 0

使用快嘉sdkg极速搭建接口模拟系统

在具体项目研发过程中,一旦前后端双方约定好接口,前端和app同事就会希望后台同事可以尽快提供可供对接的接口方便调试,而对后台同事来说定好接口还仅是个开始、设计流程,实现业务逻辑,编...

fastjrun ⋅ 今天 ⋅ 0

PXE/KickStart 无人值守安装

导言 作为中小公司的运维,经常会遇到一些机械式的重复工作,例如:有时公司同时上线几十甚至上百台服务器,而且需要我们在短时间内完成系统安装。 常规的办法有什么? 光盘安装系统 ===> 一...

kangvcar ⋅ 昨天 ⋅ 0

使用Puppeteer撸一个爬虫

Puppeteer是什么 puppeteer是谷歌chrome团队官方开发的一个无界面(Headless)chrome工具。Chrome Headless将成为web应用自动化测试的行业标杆。所以我们很有必要来了解一下它。所谓的无头浏...

小草先森 ⋅ 昨天 ⋅ 0

Java Done Right

* 表示难度较大或理论性较强。 ** 表示难度更大或理论性更强。 【Java语言本身】 基础语法,面向对象,顺序编程,并发编程,网络编程,泛型,注解,lambda(Java8),module(Java9),var(...

风华神使 ⋅ 昨天 ⋅ 0

Linux系统日志

linux 系统日志 /var/log/messages /etc/logrotate.conf 日志切割配置文件 https://my.oschina.net/u/2000675/blog/908189 logrotate 使用详解 dmesg 命令 /var/log/dmesg 日志 last命令,调......

Linux学习笔记 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部