《演进式架构》 —— 适应度函数

CFR软件不同的维度

除了业务需求的变化,还有这些非功能性需求的变化
https://en.wikipedia.org/wiki/List_of_system_quality_attributes

image.png

软件生态系统的变化

增量的(incremental change)、引导式的(guided change)往软件中引入变化。

适应度函数(fitness function)

评估一个算法是否更加接近目标的函数,契合了引导性的概念。
架构的适应度函数指的是为某些架构特征提供了客观的完整性评估。


image.png

需求是可以通过一些测试来保证的,但是其他的维度就不能了。

fitness function:针对架构特征进行的测试就是fitness function

分类

  • 原子适应度函数:单个维度的校验

  • 整体适应度函数:例如包含了安全性和性能之间的衡量的一个适应度函数。

  • 触发式适应度函数:例如流水线上触发的校验

  • 持续性适应度函数:频繁的运行的,例如日志警告(普罗米修斯这样的工具)、线上的monitor等。

  • 静态适应度函数:非0或1,及通过或不通过

  • 动态适应度函数:例如访问量到了某一定规模时,性能有新的指标

  • 自动式适应度函数:自动化到pipeline上的。

  • 手动适应度函数:例如手动的安全审查手段。

  • 临时适应度函数:在某种情况下发生时要做的适应度函数。例如当发现dependencies有更新的时候,采取的一些措施。

尽早评估和确定适应度函数并持续审查适应度函数

确定维度:很重要但是不是关键的维度、不相关的维度等等,都是需要去确定的。
不断的审查适应度函数是否能校验你的维度,适应度函数规模是否会变大或变小,有没有更好的方法去校验这些维度。

开展增量变更

例:当有一个老的系统需要更新时,新建了一个新的系统,把用户流量导入新的系统,建立monitor,监测没有问题后才把老系统关掉。【旧的不变,新的创建,一步切换,旧的再见】

image.png

把架构守护加入到流水线中去,会加入原子的适应度函数,保证单个服务的架构守护。例如ArchUnit 完成分层架构不越界的检查;多线程环境下login的完整性。

适应度函数组合

原子+触发:流水线上针对安全的一系列校验。
整体+触发:流水线上performance的校验。
原子+持续:日志收集,告警反馈。
整体+持续:Netflix 的 Chaos Monkey

总结

这些维度在记录架构决策的变更时更具有说服力。

涉及网站:
Building Evolutionary Architectures

参考书籍:
《演进式架构》

你可能感兴趣的:(《演进式架构》 —— 适应度函数)