一种基于特性开关以及规则的软件开发模式

以下是一些简单的思考

一般开发模式

  • 参考图

 

 

  • 说明

我们提供多种api 实例,通过强大的规则以及路由能力提供api 以及数据的处理

基于rule 模式的

  • 参考图

 

 

  • 说明 
    将业务处理使用rule 解耦,同时提供了多实例的副本,其中rule 可以加入审计以及可视化展示,注意此图没有使用特性开关 
    对于复杂的处理我们还是需要依赖强大的路由能力解决(当然可以解决我们大部分的复杂业务问题)

基于rule+ Feature Flags

  • 参考图

 

 

  • 说明 
    api 的版本都是一致的,对于复杂业务处理基于rule,同时包含了审计以及dashboard,同样还是利用了强大的路由能力。 
    好处:版本一致,可以全局灵活的调整业务api以及功能的处理,对于复杂业务基于rule处理增强了业务的处理

说明

一些实践,特性开关不同语言的实现还是比较多的,java 的ff4j是一个不错的选择,java 的easy-rules 是一个简单、灵活的规则 
引擎(drools 也是不错的)

posted on 2020-04-19 22:49  荣锋亮  阅读(586)  评论(0编辑  收藏  举报

导航