简介
功能开关发布是指新功能和老功能放在同一套代码中,新功能隐藏在开关后面,如果开关没有打开,则走老代码逻辑,如果开关打开,则走新代码逻辑。技术实现上可以理解为一个简单的 if/else 逻辑。
应用上线后,开关先不打开,然后运维或研发人员通过配置中心打开新功能,经过流量验证新功能没有问题,则发布完成;如果有问题,则随时可以通过开关中心切回老功能逻辑。
优势
- 升级切换和回退速度非常快。
- 相对于复杂的发布工具,实施比较简单,成本相对低廉。
- 研发能够灵活定制发布逻辑。
不足
- 对代码有侵入,代码逻辑会变复杂,所有条件判断、开关逻辑需要提前预埋在代码中
1、客户端获取配置时上传参数:
- source(iOS、Android、WAP、PC、微服务)
- userId(为空时代表未登录)
2、配置下发规则:
全量发送所有开关信息,由客户端根据配置信息中的条件来做处理
客户端JSON格式示例:
{
"configVersion(配置的版本)" : "18"
"功能id1" : {
"key" : "service.url",
"value" : "https://www.rrjc.com",
"comment" : "服务Url",
"appVersion(app版本)" : ">= 3.0.0", // 使用语义化版本规则 http://www.u396.com/semver-range.html
"mid(唯一标识)" : "['xxxx1', 'xxxx2']",
"rate(灰度百分比)" : "10",
},
"功能id2" : {
"key" : "yyz.switch",
"value" : "true",
"comment" : "月月赚产品是否开启"
"appVersion(app版本)" : ">= 3.0.0",
"mid(唯一标识)" : "['xxxx1', 'xxxx2']",
"rate(灰度百分比)" : "10",
},
"功能id3" : {
"key" : "feedback.length",
"value" : "1000",
"comment" : "feedback最大长度限制",
"appVersion(app版本)" : ">= 3.0.0",
"mid(唯一标识)" : "['xxxx1', 'xxxx2']",
"rate(灰度百分比)" : "10",
},
"功能id4" : {
"key" : "webView.cache.enabled",
"value" : "false",
"comment" : "是否开启webview缓存",
"appVersion(app版本)" : ">= 3.0.0",
"mid(唯一标识)" : "['xxxx1', 'xxxx2']",
"rate(灰度百分比)" : "10",
}
}
微服务JSON格式示例:
{
"configVersion(配置的版本)" : "110"
"功能id1" : {
"key" : "service.address",
"value" : "https://www.szrrjc.com:8443",
"comment" : "微服务切换实例",
"appVersion(app版本)" : ">= 3.0.0",
"area(地区)" : "['深圳', '广州']",
"rate(灰度百分比)" : "10",
},
"功能id2" : {
"key" : "api.yyz",
"value" : "v3/yyz/products",
"comment" : "修改接口调用",
"appVersion(app版本)" : ">= 3.0.0",
"area(地区)" : "['深圳', '广州']",
"rate(灰度百分比)" : "10",
},
}
3、配置中心需要包含功能:
- 配置编辑:创建、修改、删除配置,配置更改实时生效
- 发布、回滚配置
- 查看发布历史
- 支持通过白名单
- 支持灰度发布、A\B 发布、全量发布 、回滚发布
- 不同集群的配置管理、不同集群间滚动式发布
- 配置信息监控:查看配置的实时生效情况
白名单:通过将对应的id放到
mid
中来实现
灰度:通过设计rate,eg:设置"rate" : "25"
,则客户端通过mid%100 <= 25来执行开关规则
A\B 发布:设置"rate" : "50"