0. 引子:人类怎样应对复杂性?

复杂性

在任何程序(可以向外延伸到其他很多领域)的生命周期中,复杂性都会不可避免地增加。
程序越大,工作的人越多,管理复杂性就越困难,程序员在修改系统时将所有相关因素牢记在心中变得越来越难;这会减慢开发速度并导致错误,从而进一步延缓开发速度并增加成本。

很多大型系统的本质问题是复杂性问题,数百个甚至更多的微服务相互调用/依赖,组成一个组件数量大、行为复杂、时刻在变动(发布、配置变更)当中的动态的、复杂的系统。

如果,我们将领域问题的复杂度与技术细节的复杂度混合在了一起,这最终将导致——整体复杂度的指数级增长。

复杂性的一个衡量维度:

  • 可维护性/可修改性
  • 一致性
  • 可读性/清晰性
  • 可测试性

降低系统复杂性:一致性

Singe Source of Truth(SSO)

一致性是降低系统复杂性并使其行为更明显的强大工具。如果系统是一致的,则意味着相似的事情以相似的方式完成,而不同的事情则以不同的方式完成。一致性会产生认知影响力:一旦您了解了某个地方的工作方式,就可以使用该知识立即了解其他使用相同方法的地方。如果系统的实施方式不一致,则开发人员必

更多推荐

软件架构设计的核心:抽象与模型、“战略编程”