我爱编程

移动端功能开关技术方案

2018-04-13  本文已影响0人  CHEN_JC

简介

功能开关发布是指新功能和老功能放在同一套代码中,新功能隐藏在开关后面,如果开关没有打开,则走老代码逻辑,如果开关打开,则走新代码逻辑。技术实现上可以理解为一个简单的 if/else 逻辑。

应用上线后,开关先不打开,然后运维或研发人员通过配置中心打开新功能,经过流量验证新功能没有问题,则发布完成;如果有问题,则随时可以通过开关中心切回老功能逻辑。

优势
不足

1、客户端获取配置时上传参数:

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、配置中心需要包含功能:

白名单:通过将对应的id放到mid中来实现
灰度:通过设计rate,eg:设置"rate" : "25",则客户端通过mid%100 <= 25来执行开关规则
A\B 发布:设置"rate" : "50"

4、客户端获取配置流程图如下:

客户端收到配置并生效后要提交信息至配置中心,以便配置中心记录配置的实时生效情况
流程.png
上一篇 下一篇

猜你喜欢

热点阅读