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

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

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

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 腾讯游戏一直是腾讯最赚钱的部门,其蓝鲸体系以“独特”的方式承载着半个腾讯,也承载着国内游戏行业半数份额。 蓝鲸是腾...
    zwwsense阅读 12,122评论 1 55
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 13,884评论 1 32
  • 七月八号,晚,我来到河北省的一个县城,安平。 舍友总是向我吹嘘,世界丝网看中国,中国丝网看安平。 我终于是见到了,...
    王成长阅读 2,498评论 0 0
  • 读库十二年了。去之前有些忐忑,忙忙订好了18年的读库,仿佛这样才够资格去参加,也怯怯地生怕听到的都是一些我不知道的...
    bb2ec6e297b5阅读 2,761评论 0 1
  • 塞上花开的布景太直了,就像一眼就能看到不穿衣服的美女不是真美女。
    欢乐欢乐多阅读 1,783评论 0 0

友情链接更多精彩内容