0. 引子:人类怎样应对复杂性?
复杂性
在任何程序(可以向外延伸到其他很多领域)的生命周期中,复杂性都会不可避免地增加。
程序越大,工作的人越多,管理复杂性就越困难,程序员在修改系统时将所有相关因素牢记在心中变得越来越难;这会减慢开发速度并导致错误,从而进一步延缓开发速度并增加成本。
很多大型系统的本质问题是复杂性问题,数百个甚至更多的微服务相互调用/依赖,组成一个组件数量大、行为复杂、时刻在变动(发布、配置变更)当中的动态的、复杂的系统。
如果,我们将领域问题的复杂度与技术细节的复杂度混合在了一起,这最终将导致——整体复杂度的指数级增长。
复杂性的一个衡量维度:
- 可维护性/可修改性
- 一致性
- 可读性/清晰性
- 可测试性
降低系统复杂性:一致性
Singe Source of Truth(SSO)
一致性是降低系统复杂性并使其行为更明显的强大工具。如果系统是一致的,则意味着相似的事情以相似的方式完成,而不同的事情则以不同的方式完成。一致性会产生认知影响力:一旦您了解了某个地方的工作方式,就可以使用该知识立即了解其他使用相同方法的地方。如果系统的实施方式不一致,则开发
版权归原作者 禅与计算机程序设计艺术 所有, 如有侵权,请联系我们删除。