演进式架构

  • 演进能力是一种元特征和保护其他所有架构特征的架构封装器
  • IEEE 的软件架构定义中的4+1
    视图模型。它关注不同角色的不同视角,将整个系统划分成了逻辑视图、开发视图、进程视图和物理视图
  • 架构师确定了可审计性、数据、安全性、性能、合法性和伸缩性是该应用的关键架构特征。随着业务需求不断变化,每个架构特征都通过适应度函数来保护其完整性。
  • 康威描述道,在设计的最初阶段,人们首先需要高瞻远瞩地思考如何将职责划分为不同的模式。团队分解问题的方式会左右他们之后的选择,这便是康威定律。
    康威特别提醒软件架构师,不要只关注软件架构和设计,还应关注团队之间委派、分配和协调工作的方式。
  • 演进式架构主要由三方面构成:增量变化、适应度函数和适当的耦合

适应度函数:

  • 全系统适应度函数允许架构师通过统一的机制思考不同的问题,捕捉和保留重要的架构特征。
  • 原子适应度函数与整体适应度函数、触发式适应度函数与持续式适应度函数、静态适应度函数与动态适应度函数、自动适应度函数与手动适应度函数\临时适应度函数、针对特定领域的适应度函数
    尽早确定 适应度函数、预设式高于应急式、审查适应度函数

实施增量变更:

只有成功完成了架构设计、实现、升级和无法避免的变更后,甚至当架构能够经受由前期未知的未知因素引起的反常事件(第6 章将介绍)带来的考验时,架构师才能评价架构的长期有效性
驱动敏捷软件方法论的引擎是内置的反馈环,如测试、持续集成和迭代等。然而包含应用程序最终用户的反馈环已经脱离了团队的控制。使用假设驱动开发,我们能以一种前所未有的方式将最终用户纳入构建流程,从他们的行为中学习并构建出对其真正有价值的系统

架构耦合:

  • 模块化-模块意味着逻辑分组,而组件意味着物理划分。
  • 架构的量子和粒度-架构量子则是具有高功能内聚并可以独立部署的组件,它包括了支持系统正常工作的所有结构性元素。在单体架构中,量子就是整个应用程序,每个部分都高度耦合,因此开发人员必须对其进行整体部署。微服务架构在架构元素之间定义了物理限界上下文,封装了所有可能变化的部分。这种架构就是为了增量变更而设计的。
  • 不同类型架构的演进能力
    -大泥团-非结构化单体、分层单体、模块化的单体架构、微内核架构、事件驱动架构
  • 微服务架构通常遵循以下七个原则:
    1-围绕业务领域建模,微服务的目标是创建有用的限界上下文,而不是让开发人员构建更小的服务
    2-隐藏实现细节,微服务的技术架构封装在基于业务领域的服务边界中。每个领域形成一个物理限界上下文。服务间通过传递消息或资源来集成,而不是通过暴露实现细节集成
    3-自动化文化,支持持续交付
    4-高度去中心化,微服务形成了一种无共享架构,其目标是尽可能地减少耦合。通常重复好于耦合
    5-独立部署,可以独立部署每个服务(包括基础设施),反映了服务间的物理限界上下文
    6-隔离失败,每个服务都应该处理合理的错误场景并在可能的情况下将其恢复。
    7-高度可观察
  • 微服务的主要目标是通过物理限界上下文来隔离领域及理解问题领域。因此,它的架构量子就是服务,这使得它成为了演进式架构的优秀示例
    常用于迁移的架构是基于服务的架构,有三个明显的区别,分别是服务粒度、数据库范围和集成中间件。
    更大的服务粒度、数据库作用域、集成中间件
  • 基于服务的架构内在的演进能力肯定比ESB 驱动的SOA 架构要好。开发人员偏离限界上下文的程度决定了架构量子的大小和破坏性耦合的数量。
  • “无服务”架构-BaaS(后端即服务)是那些明显或从根本上依赖于第三方应用或云端服务的应用、FaaS(功能即服务)

演进式数据:

  • 是经过检验的、版本化的和增量的
  • 架构师必须考虑应用的所有耦合特征,其中包括类、包/ 命名空间、库、框架、数据库模式,以及事务上下文。在架构演进时,忽视其中任一维度(或维度间的交互)都将产生问题。
  • 在将单体架构迁移到某种更精细的架构时,应该从分离少量较大的服务开始。当构建一个全新的微服务架构时,开发人员应该尽量限制服务和数据上下文的大小。然后,不要仅按字面意思来理解微服务,对每个服务而言,小并不是必需的,能捕获有用的限界上下文才是关键。
  • 数据的年龄和质量,识别真正有用的数据并将其保留下来,将旧数据作为参考但不将其纳入演进式开发的主流。

构建可演进的架构:

  • 演进机制-通过下面三步来构建演进式架构
    识别受演进影响的架构维度、为每个维度定义适应度函数、使用部署流水线自动化适应度函数

  • 赋予现有架构演进能力取决于三个因素:组件耦合度、工程实践成熟度,以及开发人员构建适应度函数的难易程度。

  • 团队可以通过多种划分方式将单体应用分解成服务。业务功能分组、事务边界、部署目标

  • 演进模块间的交互-拆分共享的依赖、通过JAR文件共享依赖、复制共享的库以消除耦合点。共享就是耦合的一种形式,在微服务架构中这是非常不可取的

  • 演进式架构构建指南-去除不必要的可变性、让决策可逆、演进优于预测、构建防腐层、服务模板、构建可牺牲架构、应对外部变化,传递依赖管理被视为有害的、更新库与更新框架、持续交付优于快照、服务内部版本化

  • 演进式架构的陷阱和反模式-
    为供应商为王反模式-无论从技术还是从业务流程的角度来看,将外部工具或框架置于架构的核心会严重限制架构的演进能力

  • 陷阱:抽象泄漏 底层抽象破坏会导致意外的灾难,即原始抽象泄漏,它是技术栈日渐复杂带来的副作用之一。

  • 反模式:最后10%的陷阱 在抽象范围的另一端存在着另一种复用陷阱,它隐藏在套装软件、平台和框架中。

  • 反模式:代码复用和滥用-开发人员为实现可复用所添加的钩子越多,对代码的基本可用性损害越大。

  • 微服务避免代码复用,遵循重复优于耦合的理念。

  • 当耦合点妨碍了演进或其他重要的架构特征时,通过分叉或重复来打破耦合点。
    架构师必须持续评估架构特征的适应度,保证它们仍在提供价值,避免沦为反模式。

  • 陷阱:简历驱动开发 不要为了架构而构建架构,构建架构是为了解决问题。在选择架构前,要始终理解问题域,不要本末倒置。

  • 增量变更 反模式:管理不当

  • 当开发人员构建单体架构时,管理决策将影响所有项目。因此,在选择数据库时,架构师必须了解每个项目需要的能力,并考虑最复杂的情况。

  • 陷阱:发布过慢 ,一个项目的生产周期决定了架构的演进速度。换句话说,演进速度和生产周期成正比

  • 业务问题 陷阱:产品定制 为每个客户定制、永久的功能开关、产品驱动定制化

  • 反模式:报表

  • 陷阱:规划视野

实践演进式架构:

  • 以领域为中心的团队应该是全功能的,这意味着每个项目角色都由该项目组成员承担
  • 架构师设计架构来消除不当耦合,以简化增量变更。、全功能团队的目标之一便是消除协调摩擦
  • 围绕业务能力组织团队:按照业务能力而非职能来组织团队
  • 产品高于项目
  • 团队成员间的连接数:尽量减少开发团队之间的连接数。
  • 团队的耦合特征-文化、事不过三,三则重构
  • 试验文化-从外部吸收想法、鼓励明确的改进、进行探针试验并稳定下来、创造创新时间、采用基于集合的开发方式、连接工程师和最终用户
  • 公司为何决定构建演进式架构
    可预测性与可演进性、规模、高级业务能力、以生产周期为业务指标

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/38831.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习:特征工程之特征预处理

目录 特征预处理 1、简述 2、内容 3、归一化 3.1、鲁棒性 3.2、存在的问题 4、标准化 ⭐所属专栏:人工智能 文中提到的代码如有需要可以私信我发给你😊 特征预处理 1、简述 什么是特征预处理:scikit-learn的解释: provide…

linux系统服务学习(六)FTP服务学习

文章目录 FTP、NFS、SAMBA系统服务一、FTP服务概述1、FTP服务介绍2、FTP服务的客户端工具3、FTP的两种运行模式(了解)☆ 主动模式☆ 被动模式 4、搭建FTP服务(重要)5、FTP的配置文件详解(重要) 二、FTP任务…

Python基础语法入门(第二十天)——文件操作

一、基础内容 在Python中,路径可以以不同的表现形式进行表示。以下是一些常用的路径表现形式: 1. 绝对路径:它是完整的路径,从根目录开始直到要操作的文件或文件夹。在Windows系统中,绝对路径以盘符开始,…

【学会动态规划】环形子数组的最大和(20)

目录 动态规划怎么学? 1. 题目解析 2. 算法原理 1. 状态表示 2. 状态转移方程 3. 初始化 4. 填表顺序 5. 返回值 3. 代码编写 写在最后: 动态规划怎么学? 学习一个算法没有捷径,更何况是学习动态规划, 跟我…

CSS 两栏布局和三栏布局的实现

文章目录 一、两栏布局的实现1. floatmargin2. flaotBFC3. 定位margin4. flex 布局5. grid布局 二、三栏布局的实现1. float margin2. float BFC3. 定位 margin(或者定位BFC)4. flex布局5. 圣杯布局6. 双飞翼布局 一、两栏布局的实现 两栏布局其实就是左侧定宽,…

高层建筑全景vr火灾隐患排查模拟培训软件助力群众防范火灾伤害

随着城市化进程的加快,楼宇建筑的数量也在不断增加。然而,楼宇消防安全问题也日益突出。为了提高楼宇员工和居民的消防安全意识,楼宇VR消防安全教育培训应运而生。VR安全培训公司深圳华锐视点制作的楼宇vr消防安全教育培训,包括消…

谷粒商城第十一天-完善商品分组(主要添上关联属性)

目录 一、总述 二、前端部分 2.1 改良前端获取分组列表接口及其调用 2.2 添加关联的一整套逻辑 三、后端部分 四、总结 一、总述 前端部分和之前的商品品牌添加分类差不多。 也是修改一下前端的分页获取列表的接口,还有就是加上关联的那一套逻辑,…

nginx负载均衡与反向代理与正向代理

负载均衡:通过反向代理来实现 正向代理的配置方法。 正向代理: 工作原理:用户端直接访问不了,需要通过代理服务器来访问web服务器,用户端先访问代理服务器,再访问web服务器。web服务器响应给代理服务器&a…

【C语言】调试技巧

目录 一、什么是bug? 二、调试 1.一般调试的步骤 2.Debug 和 Release 三、调试环境准备 四、调试时要查看的信息 1.查看临时变量的值 2.查看内存信息 3.查看调用堆栈 4.查看反汇编信息 5.查看寄存器 五、练习 六、常见的coding技巧 七、const的作用 八、编程常见…

Linux - MongoDB 数据库自动退出服务问题/闪退

问题:MongoDB 自动退出服务问题 原因: 由于 Mongodb 服务,使用过多系统内存,导致系统强制停止 Mongodb 服务。 解决方法: 在 mongodb.conf 配置文件内,添加新配置内容: wiredTigerCacheSi…

POI与EasyExcel--写Excel

简单写入 03和07版的简单写入注意事项: 1. 对象不同:03对应HSSFWorkbook,07对应XSSFWorkbook 2. 文件后缀不同:03对应xls,07对应xlsx package com.zrf;import org.apache.poi.hssf.usermodel.HSSFWorkbook; import …

如何应用项目管理软件进行敏捷开发管理

敏捷开发(Agile Development)是一种软件开发方法论,强调在不断变化的需求和环境下,通过迭代、协作和自适应的方式来开发软件。敏捷方法的目标是提供更快、更灵活、更高质量的软件交付,以满足客户需求并实现项目成功。 …

服务器数据恢复-EqualLogic存储RAID5数据恢复案例

服务器数据恢复环境: 一台DELL EqualLogic存储中有一组由16块SAS硬盘组建的RAID5阵列。存储存放虚拟机文件,采用VMFS文件系统,划分了4个lun。 服务器故障&检测&分析: 存储设备上有两个硬盘指示灯显示黄色,存储…

【Windows 常用工具系列 6 -- CSDN字体格式(字体、颜色、大小)、背景色设置】

文章目录 背景字体大小设置字体颜色设置字体类型背景色 上篇文章:Windows 常用工具系列 5 – Selenium IDE的使用方法 下篇文章:Windows 常用工具系列 7 – 禁用win10自带的微软输入法 背景 Markdown是一种轻量级标记语言,它的目标是实现“…

1022.从根到叶的二进制之和

目录 一、题目 二、代码 一、题目 二、代码 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nu…

基于java计算机类考研交流平台设计与实现

摘要 高校的大学生考研是继高校的高等教育更上一层的表现形式,教育的发展是我们社会的根本,那么信息技术的发展又是改变我们生活的重要因素,生活当中各种各样的场景都存在着信息技术的发展。信息技术发展WEB信息化的到来让人们的生活感受到了…

vue项目的实用性总结

1、mockjs 基本使用 ★ 安装:npm i mockjs。 在src/mock/index.js内容如下: import Mock from mockjs //制订拦截规则 Mock.mock(http://www.0313.com,get,你好啊)记得在main.js中引入一下,让其参与整个项目的运行。 只要发出去的是get类型…

家纺行业小程序商城搭建指南

家纺行业作为一个不可或缺的消费领域,近年来备受关注。随着互联网的发展,小程序商城成为家纺行业拓展市场的新利器。搭建一个家纺行业小程序商城并不是一件困难的事情,只需要按照以下几个步骤进行操作,就能轻松上手。 首先&#x…

Java后端框架模块整合

提示:使用Java后端开发框架能够提高开发效率、代码质量,提升可扩展性,降低开发成本和易于维护。 文章目录 前言MyBatis 框架知识Spring 框架知识SpringMVC 框架知识SpringBoot 框架知识 前言 提示:这里可以添加本文要记录的大概内…

2023-08-15 LeetCode每日一题(字符串中的查找与替换)

2023-08-15每日一题 一、题目编号 833. 字符串中的查找与替换二、题目链接 点击跳转到题目位置 三、题目描述 你会得到一个字符串 s (索引从 0 开始),你必须对它执行 k 个替换操作。替换操作以三个长度均为 k 的并行数组给出:indices, sources, tar…