美文网首页
《演进式架构》 —— 适应度函数

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

作者: 前端进城打工仔 | 来源:发表于2019-10-12 11:31 被阅读0次

    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

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

    相关文章

      网友评论

          本文标题:《演进式架构》 —— 适应度函数

          本文链接:https://www.haomeiwen.com/subject/fwvuuctx.html