简体中文
App升级中心 uni-upgrade-center,提供了 App 的版本更新服务。包括
如果需要初次发布,而不是升级,另见产品 uni-portal 统一发布页
本产品具有如下特征:
每个App开发者都要开发升级功能,这是巨大的社会资料浪费。DCloud推出 uni-upgrade-center,让应用开发更轻松、高效,让开发者专注于自己的业务。
升级中心分为两个部分:uni-upgrade-center Admin管理后台 和 uni-upgrade-center-app前台检测更新。
负责发布新版和管理历史版本的上下线。提供了如下功能:
云储存安装包CDN加速,使安装包下载的更快、更稳定
应用管理,对 App 的信息记录和应用版本管理
版本管理,可以发布新版,也可方便直观的对当前 App 历史版本以及线上发行版本进行查看、编辑和删除操作
版本发布信息管理,包括 更新标题,更新内容,版本号,静默更新,强制更新,灵活上线发行 的设置和修改
原生 App 安装包,发布 Apk 更新,用于 App 的整包更新,可设置是否强制更新
wgt 资源包,发布 wgt 更新,用于 App 的热更新,可设置是否强制更新,静默更新
App 管理列表及 App 版本记录列表搜索
新建 uni-admin 项目
新建项目:打开HBuilderX
-> 文件
-> 新建
-> 项目
-> uni-app
选择 uniCloud admin
模板,键入一个名字,确定
鼠标右键 uniCloud 文件夹
选择关联云服务空间
和运行云服务空间初始化向导
添加应用
运行 uni-admin 到浏览器,在左侧菜单
系统管理 -> 应用管理
中新增应用后,即可在App升级中心
发布该应用的版本 详情
添加应用后,即可在应用管理列表中跳转至版本管理页面:
版本管理
发布新版
,可以发布原生App安装包
和wgt资源包
。在左上角点击下拉列表
,可以切换展示应用。发布原生App安装包
版本号
:请填写以.
分隔字符串,例如:0.0.1
。在构建应用安装包时,manifest.json
中的 应用版本名称
也要是该格式。
Android应用市场
新增应用
时填写的 Android应用市场
信息保持同步。当在应用管理修改应用信息时,这里也会修改upgrade-center-app
端会检测手机上是否有该应用市场
下载链接
下载 apk 安装包升级下载链接/AppStore
云存储
,会自动将地址填入该项苹果
版本,包地址则为应用的 AppStore 链接
强制更新
上线发行
发布wgt资源包
原生App安装包
一致原生App最低版本
新的 api
或者打包了 新的模块
,则在发布 wgt资源包
的时候,要将 原生App最低版本
填写为本次版本wgt资源包
,则会自动带出静默更新
发布完成页面
Tips
/uni_modules/uni-upgrade-center/pages/version/add.vue
中有版本对比函数(compare)。
\uni_modules\uni-upgrade-center\pages\mixin\version_add_detail_mixin.js
将
data
中的enableiOSWgt
属性设置为true
即可
负责前台检查升级更新。
提供了如下功能:
基于uni-upgrade-center
一键式检查更新,统一整包与 wgt 资源包更新
自行根据传参完成校验,判断此次更新使用哪种方式
一键式升级。弹框、下载、安装、是否强制重启等逻辑已集成
下载完成如果取消升级自动缓存安装包,下次进入判断是否符合安装条件,判断不通过则自动清除
美观,实用,可自定义扩展
美观,实用,可自定义扩展
安装指引
在插件市场打开本插件页面,在右侧点击使用 HBuilderX 导入插件
,选择要导入的项目点击确定 插件地址
创建 uniCloud 云开发环境
绑定服务空间:
>= 0.6.0
,依赖 uni-admin 1.9.3+
的 uni-upgrade-center 云函数
,请和 uni-admin 项目关联同一个服务空间<= 0.6.0
,请绑定到一个已有的服务空间或者新建一个服务空间进行绑定上传云函数:
>= 0.6.0
,依赖 uni-admin 1.9.3+
的 uni-upgrade-center 云函数
,插件不再单独提供云函数,可以跳过此步骤<= 0.6.0
,找到/uni_modules/uni-upgrade-center-app/uniCloud/cloudfunctions/check-version
,右键上传部署在pages.json
中添加页面路径。注:请不要设置为pages.json中第一项
"pages": [
// ……其他页面配置
{
"path": "uni_modules/uni-upgrade-center-app/pages/upgrade-popup",
"style": {
"disableScroll": true,
"app-plus": {
"backgroundColorTop": "transparent",
"background": "transparent",
"titleNView": false,
"scrollIndicator": false,
"popGesture": "none",
"animationType": "fade-in",
"animationDuration": 200
}
}
}
]
将@/uni_modules/uni-upgrade-center-app/utils/check-update.js
使用 import 导入到需要用到的地方,调用一下即可:
import checkUpdate from '@/uni_modules/uni-upgrade-center-app/utils/check-update.js'
callFunction
。详情升级弹框可自行编写,也可以使用uni.showModal
,或使用现有的升级弹框样式,如果不满足UI需求请自行替换资源文件。在utils/check-update.js
中都有实例。
使用wgt更新,打包前请务必将 manifest.json 中的版本名称修改为更高版本。
更新下载安装check-update.js
该函数在utils目录下
如果是静默更新,则不会打开更新弹框,会在后台下载后安装,下次启动应用生效
如果是 iOS,则会直接打开AppStore的链接
其他情况,会将检查更新云函数返回的结果保存在localStorage中,并跳转进入upgrade-popup.vue
打开更新弹框
Tips
近期,uniCloud阿里云版开始正式商用,部分开发者对基于uniCloud的uni-upgrade-center
等云端一体业务,开始纠结,不清楚这些业务预计会花费多少钱,不清楚相比传统服务器而言,何种方案性价比更好。
本文尝试算细账、算总账,以阿里云按量计费为例,详细预测uni-upgrade-center
在不同用户规模下的资源消耗及对应费用,帮助大家明智选择,无忧开发。
本文主要分为三个部分:
uni-upgrade-center
消耗的资源费用测算(云函数、云数据库、云存储、前端网页托管分别测算)uni-upgrade-center
给你带来的收益uni-upgrade-center
升级中心涉及费用的部分主要分为:
uni-upgrade-center
云函数,将客户端版本和服务端最新版本进行对比,返回是否需升级的逻辑opendb-app-versions
表,存储版本信息uni-admin
,管理员发布新版本接下来,我们对不同资源,分别进行费用评估。
启用uni-upgrade-center
升级中心后,你的App每次启动,会请求一次uni-upgrade-center
云函数。
我们按照uniCloud官网列出的按量计费规则,可以得出如下云函数资源消耗计算公式:
云函数费用 = 资源使用量 * 0.000110592 + 调用次数 * 0.0133 / 10000 + 出网流量 * 0.8
其中:
我们假设如下数据模型:
uni-upgrade-center
云函数建议设置为256M按照如上公式,你的App若有100个日活用户,其升级中心云函数每天的费用为:
云函数费用(天) = 资源使用量 * 0.000110592 + 调用次数 * 0.0133 / 10000 + 出网流量 * 0.8
= 云函数内存(单位为G) * 云函数平均单次执行时长(单位为秒) * 调用次数 + 调用次数 * 0.0133 / 10000 + 出网流量 * 0.8
= 0.25G * 0.1S * 100 * 2 * 0.000110592 + 100 * 2 * 0.0133/10000 + 0
= 0.00081896(元)
即:你的App日活为100,使用uni-upgrade-center
商业版后,对应云函数每天大概消耗0.00081896元。
据此,可计算其每月的费用为:0.00081896 * 30 = 0.0245688,即每月只需2分钱;
同理,我们可推导出日活为1000、10000、10万的App,其升级中心云函数每月费用如下表:
日活 | 资源使用量计费(元) | 调用次数计费(元) | 出网流量计费(元) | 合计(元) |
---|---|---|---|---|
100 | 0.0165888 | 0.00798 | 0 | 0.0245688 |
1000 | 0.165888 | 0.0798 | 0 | 0.245688 |
10000 | 1.65888 | 0.798 | 0 | 2.45688 |
100000 | 16.5888 | 7.98 | 0 | 24.5688 |
日活1000的App,云函数月度消耗才两毛五(0.25元),真是毛毛雨了。
按照uniCloud官网介绍,云数据库费用 = 容量费用 + 读操作次数费用 + 写操作次数费用
,其中:
我们以hello uni-app
为例,opendb-app-versions
数据表中共存储30条升级记录,容量大小为8K。
据此可计算出opendb-app-versions
表的日存储费用为:8/1024/1024 * 0.07 = 0.000000534
容量计费单位是G,故需先将8K折算成M,再折算成G,故上述公式中连续除了两个1024
1月按30天算,则月存储费用为0.000000534 * 30 = 0.000016
,还不到1分钱,可忽略。
注意:数据库容量仅跟发布版本多少有关系,跟日活用户无关。
在uni升级中心业务中,云函数uni-upgrade-center
每次执行,仅调用一次数据库读取(读取一次opendb-app-versions
表),故数据库的读操作次数等同于云函数的调用次数
,前文有过公式,云函数调用次数 = App日活 * 每日活用户平均每天启动App次数
,每日活用户平均每天启动App次数我们假设为2次。
我们即可推算,如果一个App的日活为100,则uni升级中心每日云数据库读操作次数费用计算如下:
读操作次数费用 = 读操作次数(万次) * 0.015
= 云函数调用次数(万次) * 0.015
= App日活 * 每日活用户平均每天启动App次数 / 10000 * 0.015
= 100 * 2 / 10000 * 0.015
= 0.0003
1月按30天算,则每月云数据库读操作次数费用为0.0003 * 30 = 0.009
,还不到1分钱。
同理,我们可推导出日活为1000、10000的App,其uni升级中心每月云数据库读操作次数费用为9分钱、9毛钱。
uni-upgrade-center
升级中心,写数据库操作很少;管理员仅在每次发布新版时,通过uni-admin
向opendb-app-versions
表插入一条新版本信息;用户端App每次启动检查升级,无需数据表的写入操作,故写操作次数可忽略为0;
因为容量费和写操作次数费用均可忽略为0,根据公式:
云数据库费用 = 容量费(忽略为0) + 读操作费用 + 写操作费用(忽略为0)
= 读操作费用
可推导,uni升级中心的云数据库计费主要是读操作次数计费,因此我们进一步得出如下预测:
日活 | 容量费(元) | 读操作次数费用(元) | 写操作次数费用(元) | 合计(元) |
---|---|---|---|---|
100 | 0 | 0.009 | 0 | 0.009 |
1000 | 0 | 0.09 | 0 | 0.09 |
10000 | 0 | 0.9 | 0 | 0.9 |
100000 | 0 | 9 | 0 | 9 |
按照uniCloud官网介绍,云存储费用 = 容量费 + 下载操作次数计费点 + 上传操作次数计费点 + CDN流量费
。
如果您的应用每次均上架到apple store或安卓各应用商店,升级时从应用商店下载安装,则云存储费用为0,因为使用的是应用商店的存储和CDN下载流量,本计费点测评章节可直接跳过。
uni-upgrade-center 支持设置应用新版安装包下载地址为应用商店地址,这样就可以使用应用商店的存储和CDN,不消耗uniCloud的云存储资源。
现阶段,iOS平台均需上架apple store,我们可以忽略iOS平台的云存储消耗。
如果您的安卓apk安装包及wgt差量升级包全部托管在uniCloud云存储中,我们也可以算算这笔账。
容量费主要是存储费用,我们可以定期将过期版本删除,从而节省容量费。
假设我们在云存储中保留最近5个版本的文件,apk/wgt全部保留,大小假设分别为:40M、10M。
如前所言,ipa需上架apple store,不使用云存储,测评可忽略。
则每天容量费用为:5 * (40+10)/1024 * 0.0043 = 0.0010498
据此,可计算其每月30天的容量费用为:0.0010498 * 30 = 0.031494
,即只需3分钱;
注意:云存储容量仅跟保留的历史升级包多少有关系,跟日活用户无关。
下载操作次数计费点:仅触发文件下载时会触发,若无新版本下载,则不会触发。
假设你的App日活为100、月活为1500,每月发一次版本;月活用户中,50%会选择升级到新版本,我们可计算下载次数为:1500*50% = 750次
。
而云存储的下载操作次数计费规则为:每万次0.01元,即每万次下载1分钱,750次下载远还不到1分钱,故下载操作计费点可直接忽略。
每次App发版,仅需管理员上传一次新的资源包,用户App端检查升级时,不涉及上传操作,故上传操作次数计费点亦可忽略。
CDN流量费:我们假设50%概率启用wgt资源包升级(升级包为10M),50%概率为整包升级;而整包升级中,20%为苹果用户(使用apple store流量),80%为安卓用户(升级包为40M)。
则按照如上数据模型,日活为100的App,假期其月活为1500,而月活用户中,50%会选择升级到新版本,即750人选择升级,不同升级包消耗CDN流量如下:
即:日活为100的App,月度CDN流量为:3.662 + 0 + 11.719 = 15.381G
,对应费用则为:15.381 * 0.18 = 2.76858
(元)
同理,我们可推导出日活为1000的App,其升级中心云存储每月的CDN费用为27.6858元。
如果你不用uni-upgrade-center
,选择如阿里云的传统OSS + CDN
方案,同样按量计费的情况下,1PB流量以内,传统CDN都没有价格优势;传统CDN每GB的起步价为0.24元,而uniCloud云存储CDN每GB的费用为0.18元。
详见:阿里云官网CDN定价详情
1PB流量是什么概念?我们以每个安卓安装包为40M为例,需要 1 * 1024 * 1024 * 1024 / 40 = 26843546
,即需要2600万人次安装包下载才能达到1PB流量,你可以评估一下你的App何时可以达到这个量级。
具体解释一下:1PB = 1024TB,1TB = 1024G,1G = 1024M,故上面公式连乘3个1024
也有人说了,购买阿里云CDN资源包可以更便宜。确实,购买大额资源包会更便宜,但这个方案有两个缺点:
综合来看,uniCloud云存储相比传统云厂商的OSS + CDN
方案:
uni-upgrade-center
需要和uni-admin
配合使用,uni-admin
需要部署在前端网页托管中。uni-admin
主要是管理员使用,使用频次较少,流量也较低。
按照uniCloud官网介绍,前端网页托管费用 = 容量费 + 流量费
。
uni-admin
编译后为4.7M,按照官网每GB每天0.0043元的规则,uni-admin
的月度容量费为:4.7 / 1024 * 0.0043 * 30 = 0.00059
,不到1分钱,可忽略。
管理员登录uni-admin
,到升级中心管理页面浏览并发布新版,所需流量不超过3M,即使每月发布2次更新,流量费预估为:3 / 1024 * 0.18 * 2 = 0.00105
,也不到1分钱,也可忽略。
细项对比完了,我们来合并看看,使用uniCloud升级中心,到底需要花多少钱,相比传统自己研发升级逻辑、搭建升级中心,哪些地方都需要花钱,差异点在哪里?
不管是开发者自研的升级方案,还是uni-upgrade-center
,存储+CDN的费用都是必需的,前文也将传统OSS+CDN
和uniCloud云存储的性价比进行了对比,均按量计费的模式下,uniCloud更具性价比;以资源包方式购买传统CDN模式下,各有优劣。
既然两个方案,都绕不开云存储,那我们暂时抛开云存储对比,将其他各项按照日活用户规模罗列一下,看看uni-upgrade-center
在其他维度所需费用。
日活 | 云函数(元) | 云数据库(元) | 云存储(元) | 前端网页托管(元) | 合计(元) |
---|---|---|---|---|---|
100 | 0.0245688 | 0.009 | 忽略 | 0 | 0.0335688 |
1000 | 0.245688 | 0.09 | 忽略 | 0 | 0.335688 |
10000 | 2.45688 | 0.9 | 忽略 | 0 | 3.35688 |
100000 | 24.5688 | 9 | 忽略 | 0 | 33.5688 |
使用uni-upgrade-center
,免费获取、一键安装,你将获得:
如上功能,如果你使用传统模式自研,需要前后端配合开发,后端使用php/java做接口,前端发起Ajax请求,处理服务端的各种响应和错误码,处理升级弹窗提醒,这些功能做完善至少需要4个工作日。
假设工程师月薪18K,社保等综合管理成本是薪资的1.4倍,则4个工作日的综合成本为:18*1000*1.4/22 * 4 = 4582元
。
再次说回uni-upgrade-center
,相比传统方式自研升级中心,存储+CDN的钱都是要花的,我们忽略它。
其它云函数、云数据库等,虽然看起来是额外增加的费用,但实际上你使用传统php/java自研升级逻辑,除了自研人力费用,后期也是需要消耗CPU、内存、带宽资源的,只是这些费用合并到虚拟机的整体租用成本中,你无法拆出来计算罢了。
再看回刚才的计算表,以1000日活用户来说,云函数、云数据库每月才多了0.34元,每年才多了4块钱(不考虑云存储CDN的情况下),一年多花4块钱,可以省掉自研的4500多元人工费用,可以让工程师将更多精力投入核心业务中。这5块钱的买卖,不划算吗?它不香吗?
日活 | 云函数(元) | 云数据库(元) | 云存储(元) | 前端网页托管(元) | 合计(元) |
---|---|---|---|---|---|
100 | 0.0245688 | 0.009 | 忽略 | 0 | 0.0335688 |
1000 | 0.245688 | 0.09 | 忽略 | 0 | 0.335688 |
10000 | 2.45688 | 0.9 | 忽略 | 0 | 3.35688 |
100000 | 24.5688 | 9 | 忽略 | 0 | 33.5688 |
不重复制造轮子,聚焦业务,快速验证模式,实现商业增长,才应该是聪明工程师的追求。