灰度发布

灰度发布

文档状态 [ ] 草稿 [ ] 正式发布 [ √ ]正在修改
文档版本号 v1.1
文档密级 内部资料
归属部门 武汉极目未来数据科技有限公司
产品名 极目农业植保运营系统
子系统名 地面站

更新日志:

日期 版本 变更记录 作者
2018/05/30 v1.0 编写初版 余明旭
2018/05/31 v1.1 [调整] 5、实施流程 余明旭

一、定义

按照一定策略选取部分用户,让他们先行体验新版本的应用,通过收集这部分用户对新版本应用的反馈以及对新版本功能、性能、稳定性等指标进行评估,进而决定继续放大新版本投放范围直至全量升级或回滚至老版本。

二、目的

1)规避一定的发布风险,降低产品迭代升级所影响的范围。
2)根据反馈结果,做到查漏补缺
3)快速验证产品功能稳定性
4)发现重大问题,可回滚“旧版本”

三、实现步骤

图片.png

3.1、定义目标
a. 产品一般都会有明确的产品目标,灰度发布的过程通常把产品关键数据走势是否有利于既定目标的达成作为进一步进行放量的重要参考,
b. 如果灰度产品在目标数值超过未灰度用户,且产品在性能指标方面趋于稳定,例如崩溃率控制在一个合理范围,用户访问速度也在预计范围,则考虑继续放量。

3.2、制订发布策略
包括用户规模、发布频率、功能覆盖度、风险评估与回滚策略、运营策略、新旧系统部署策略等。
简单说,就是我们要分几个批次进行用户覆盖,多长时间覆盖完成,每次间隔多长时间,评估每次发布有可能面临的风险。
如果产品发生重大问题,是否能迅速回滚到上一个版本。

3.3、选定用户
包括用户特征、用户数量、用户常用功能、用户范围等。
一般的灰度用户选择都是从本公司内测开始,其次是高级别高忠诚度的用户,然后是高活跃用户,最后再到普通用户。

3.4、系统部署
部署新系统、设定分流规则、运营数据分析、分流规则微调等。
这里的运营数据部署,建议进行实时数据统计与报表展示,便于及时观测产品数据变化,快速发现问题解决问题。

3.5、反馈收集与发布分析
用户行为分析报告、错误统计反馈情况等可形成下次灰度发布的功能改进列表。
用户的反馈,从产品自带的反馈提交获取,无论是哪个渠道,都要考量这些反馈建议的代表性。用户反馈建议的收集整理输出,每天至少一次,灰度期间的主要观测数据报告需按天发出。

3.6、产品迭代
灰度过程是推动产品快速优化的有效手段,产品经理必须客观的对待用户的反馈,分析产品目标数据、用户行为数据等,拿出合理的优化方案,推动优化开发,再进行下一轮灰度或者完整发布。

四、需求涉及流程

方案一.服务端控制

许针对部分用户推送升级通知甚至版本强制升级。
无论哪种方法都需要做好版本管理工作,分配特别的版本号以示区别。
当然,既然是做灰度,数据监控(常规数据、新特性数据、主要业务数据)
还有,灰度版最好有收回的能力,一般就是强制升级下一个正式版。

方案二.客服端+服务端控制

客户端在打包的时候,将A功能B功能都打进同一个版本的Apk包里,然后在代码层写控制显示逻辑。后台接口控制当前版本显示APK上的A/B版本的分布,可以做到指定一部分用户使用A功能,一部分用户使用B功能。
服务器端应该有相应的报表来显示A/B版本的数量和使用效果对比,根据实时数据体现,再由服务器端接口控制用户全部切换到A版本或者B版本。

五、实施流程

5.1、服务端
1)新增数据表

    a. 内测白名单表:包含测试人员、开发人员、内定协商用户、用户主动申请成员名单
    b. 内测成员表:包含内测白名单表中所有成员+投放百分比人员


图片.png
2)修改接口

  a. 获取用户信息接口:/getPersonInfo/ 返回值需新增 isTester字段(1:内测人员 0:非内测人员),通过userId查询内测成员表获取。

3)新增接口

3.1 内测资格操作接口:1 申请 0 取消
a. 申请:客户端调用接口,传参 1 后台将userId加入内测白名单表
b. 取消:客户端调用接口,传参 0 发起后将userId从内测白名单表中删除,并将内测成员表中删除。为保证灰度阶段的测试百分比,一旦取消一个内测成员,将自动从总人员中随机抽取一个加入内测成员表。

3.2 新增接口:/checkVersionV2/ 不管服务端存在大于当前版本的发布版或测试版本,都将返回给客户端,由地面站根据用户信息表所有获取的isTester参数来判断是显示测试还是正式版本提示更新。

{
    "code": "000000",
    "message": "有新版本,请更新",
    "result": {
        "release": {
            "apkSize": "18.9",
            "publishTime": 1519825101000,
            "downloadUrl": "http://whjm-test.oss-cn-beijing.aliyuncs.com/app-firmware/gs/5uno=",
            "isForceUpdate": 1,
            "versionCode": "200100000",
            "updateDetail": "[修复] 任务详情接口添加参考边信息"
        },
        "beta": {
            "apkSize": "18.9",
            "publishTime": 1519825101000,
            "downloadUrl": "http://whjm-test.oss-cn-beijing.aliyuncs.com/app-firmware/gs/5uno=",
            "isForceUpdate": 1,
            "versionCode": "200100000",
            "updateDetail": "[修复] 任务详情接口添加参考边信息"
        }
    }
}

4)完善后台apk提交界面
图片.png

内测成员表默认包行内测白名单所有成员,在开启百分比投放后投放规则如下:
1)内测人员包含在总投放百分比中
2)投放用户10%,以地面站为例,因使用角色要求必须为飞手,总账户个数1000人,具有飞手角色用户500人,内测白名单成员数20人,计算公式如下:
设定百分比投放新增成员数=(有效角色总人数 * 投放百分比) - 内测白名单成员数
3)投放用户百分比变更:
增加: 增加人数 = (有效角色总人数 * 投放百分比) - 内测成员表总人数
减少: 减少人数 = 内测成员表人数 - (有效角色总人数 * 投放百分比),例如减少人数50人,随机从内测成员表中移除,过程不包含内测白名单中成员。

5.2、客户端:

1)登陆后请求用户信息表,获取isTester值
2)客户端新增版本回退UI(仅限回退上一个正式版本)
3)新增内测资格控制按钮(在开启内测资格给出弹窗,提示内测版本)
2)调用接口:/checkVersion/ 服务端将会返回release最新版本信息和beta最新版本信息

内测资格 存在新发布版 存在新测试版 提示
true true true 显示beta版本更新提示
true false true 显示beta版本更新提示
true false false 无提示
false true true 显示release版本更新提示
false false true 无提示
false false false 无提示

六、客户端灰度发布版本规则
默认情况下版本变更:
1)版本号由9位数字组成

201005101
2_01_0051_01
主版本-次版本-小版本-灰度版本

灰度发布版本变更说明:
当前功能开发的版本为 v2.1.51,开发工作结束,需要发布第一个灰度版本

灰度次数 VersionCode VersionName 通过
1 201005101 v2.1.51_1_beta false
2 201005102 v2.1.51_2_beta false
3 201005103 v2.1.51_3_beta true

如上所示,灰度发布第三版本运行一段时间后,符合全量更新的指标,则在第三版的代码的中修改VersionName:v2.1.051_release,VersionCode不变,生成一个安装包,发布一个正式版本,供非内测用户下载使用。

VersionCode VersionName
201005103 v2.1.51_release

七.总结

1.灰度发布必须做好版本管理,一旦错乱将导致一些版本无法回收更新。
2.数据的统计,收集,分析,没有一个好的数据平台就没有办法体现灰度发布所起到的作用,随之该功能就失去了意义。
``

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容