功能管理(Feature management)中的 Keystone 模式

一、什么是 Keystone ?

对软件研发团队来说,越是频繁地集成他们的代码,工作就越轻松。同时,越频繁发布功能迭代,产品就越有价值。但是团队并不想把开发了一半的功能暴露给用户。对这种矛盾的一个有效的处理机制就是先构建所有的后端代码,集成到产品,但不提供用户界面。这个功能可以在用户端无感知的情况下被集成和测试,直到全部完成上线后,再将这个功能展现给用户。就像是 Keystone(拱顶石,建筑学术语,通常引申为确保其他部件就位的核心关键点)。

keystone.png

二、限时特价促销活动

举一个简单的例子,比如说给用户推送一个限时特价商品。这样的订单一般都需要根据用户位置、配送情况等信息确定价格。所以根据用户位置、时间、商品类型等因素,决定了用户是否会收到这种限时特价商品的推送信息。

总而言之,这是一个很复杂的电商运作逻辑,因为需要涉及仓储量、商品目录、客户服务等多个系统的协同。完成这样一个流程的开发,可能需要几周的的时间,同时,另一些功能可能需要每隔几天就发布一次。而对客户而言,特价商品推送只是订单表格上的一个选择框。

在这个项目中,可以让选择框作为 Keystone。研发团队可以跨多个产品发布周期进行内部系统的业务逻辑和接口开发。用户感知不到这些代码改动。最后一步是让用户看到这个特价推送的选择框 UI 界面,通常这用不了多少开发时间。这种模式下,所有中间代码都能够参与集成,并随着产品发布周期部署在线上,这样就避免了长时间使用 feature branch(特性分支——一种分支管理模式)带来的风险。


分发模式

三、中间代码和UI界面的测试方式

中间代码需要像线上代码一样接受严格的测试。这需要系统(测试)分层搭建,而不是所有测试都依赖于用户页面的触发。单元测试和 Test Pyramid(测试金字塔)中的低层测试都应当可以正常执行。甚至 Broad Stack Test 都可以正常执行,只要提供一定的机制使它们成为 Subcutaneous Tests。某些情况下,UI 层本身包含了复杂的行为,不过只要设计得当,UI 也可以通过进入 Humble Object 的方式得到测试。

并非所有应用程序的构建方式都支持这种大覆盖面的"皮下"测试,但即使无法使用 Keystone 模式,这种设计原则也是有价值的。即使用最好的工具去自动化这一过程,从 UI 层触发的测试也总是很难搭建的。将更多的测试转移到界面层以下各层级,特别是单元测试层,可以显著提升部署流水线的速度,实现持续交付。

当然,大多数的 UI 变化会比添加一个选择框复杂,即便如此,应用 Keystone模式也并不会增加太多工作量。在 Web 应用中,一个复杂的功能通常都是一个独立页面,可以作为一个整体构建和测试。这种场景下,Keystone 就是一个链接。桌面应用可能设计多个界面变化,这种情况下,Keystone 可以是一个能展示这些界面的菜单项。

尽管如此,确实存在一些场景用户界面不能被简单地打包通过一个 Keystone 控制。这时候就需要用到功能开关了。即便在这种情况下,Keystone 的概念也能够帮助我们将功能开关的实现限定在UI层控制上。这样可以避免开关四处散落在后端代码中,降低了开关应用的复杂性,更好地贯彻单开关机制,也为后续的开关清理降低了难度。

四、总结

后端先行,最后再开发 UI 界面的方式也存在一个潜在的风险,就是后端代码的设计可能无法与后开发的UI协调一致,或者在后期UI实现时才发现设计点遗漏,这会导致反馈延迟并带来糟糕的用户体验。因此,只有在产品上支持功能垂直划分,研发上能够按功能粒度快速发布的团队中,Keystone 模式才能够发挥最大的价值。

在这里我只是举例了一个用户界面的小例子,但同样的方法适用于任何界面变化,例如 API。通过最后再提供用户界面,并且保持简洁的方式,即使是很大的功能升级,我们也可以通过逐个部分增量构建、集成来完成。

在 FeatureProbe 就可以实现 Keystone 模式,做到后端代码与UI 界面分开部署测试。研发团队可以先开发后端代码部署,用户侧无感知这一块功能核心功能已经部署到系统上了,确保新功能后端代码没有问题后,在 FeatureProbe 后台操作页面,可以一键开启 UI 界面功能,测试 UI 界面功能没有问题后,再将这个新功能开放给用户。

目前 FeatureProbe 使用 Apache 2.0 License 协议已经完全开源。你可以从 GitHubGitee 获取到所有源码。

与此同时,我们提供了无需部署的在线试用环境和一个仅需5分钟即可体验的示例项目

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

推荐阅读更多精彩内容