演进式架构
- 演进能力是一种元特征和保护其他所有架构特征的架构封装器
- IEEE 的软件架构定义中的4+1
视图模型。它关注不同角色的不同视角,将整个系统划分成了逻辑视图、开发视图、进程视图和物理视图 - 架构师确定了可审计性、数据、安全性、性能、合法性和伸缩性是该应用的关键架构特征。随着业务需求不断变化,每个架构特征都通过适应度函数来保护其完整性。
- 康威描述道,在设计的最初阶段,人们首先需要高瞻远瞩地思考如何将职责划分为不同的模式。团队分解问题的方式会左右他们之后的选择,这便是康威定律。
康威特别提醒软件架构师,不要只关注软件架构和设计,还应关注团队之间委派、分配和协调工作的方式。 - 演进式架构主要由三方面构成:增量变化、适应度函数和适当的耦合
适应度函数:
- 全系统适应度函数允许架构师通过统一的机制思考不同的问题,捕捉和保留重要的架构特征。
- 原子适应度函数与整体适应度函数、触发式适应度函数与持续式适应度函数、静态适应度函数与动态适应度函数、自动适应度函数与手动适应度函数\临时适应度函数、针对特定领域的适应度函数
尽早确定 适应度函数、预设式高于应急式、审查适应度函数
实施增量变更:
只有成功完成了架构设计、实现、升级和无法避免的变更后,甚至当架构能够经受由前期未知的未知因素引起的反常事件(第6 章将介绍)带来的考验时,架构师才能评价架构的长期有效性
驱动敏捷软件方法论的引擎是内置的反馈环,如测试、持续集成和迭代等。然而包含应用程序最终用户的反馈环已经脱离了团队的控制。使用假设驱动开发,我们能以一种前所未有的方式将最终用户纳入构建流程,从他们的行为中学习并构建出对其真正有价值的系统
架构耦合:
- 模块化-模块意味着逻辑分组,而组件意味着物理划分。
- 架构的量子和粒度-架构量子则是具有高功能内聚并可以独立部署的组件,它包括了支持系统正常工作的所有结构性元素。在单体架构中,量子就是整个应用程序,每个部分都高度耦合,因此开发人员必须对其进行整体部署。微服务架构在架构元素之间定义了物理限界上下文,封装了所有可能变化的部分。这种架构就是为了增量变更而设计的。
- 不同类型架构的演进能力
-大泥团-非结构化单体、分层单体、模块化的单体架构、微内核架构、事件驱动架构 - 微服务架构通常遵循以下七个原则:
1-围绕业务领域建模,微服务的目标是创建有用的限界上下文,而不是让开发人员构建更小的服务
2-隐藏实现细节,微服务的技术架构封装在基于业务领域的服务边界中。每个领域形成一个物理限界上下文。服务间通过传递消息或资源来集成,而不是通过暴露实现细节集成
3-自动化文化,支持持续交付
4-高度去中心化,微服务形成了一种无共享架构,其目标是尽可能地减少耦合。通常重复好于耦合
5-独立部署,可以独立部署每个服务(包括基础设施),反映了服务间的物理限界上下文
6-隔离失败,每个服务都应该处理合理的错误场景并在可能的情况下将其恢复。
7-高度可观察 - 微服务的主要目标是通过物理限界上下文来隔离领域及理解问题领域。因此,它的架构量子就是服务,这使得它成为了演进式架构的优秀示例
常用于迁移的架构是基于服务的架构,有三个明显的区别,分别是服务粒度、数据库范围和集成中间件。
更大的服务粒度、数据库作用域、集成中间件 - 基于服务的架构内在的演进能力肯定比ESB 驱动的SOA 架构要好。开发人员偏离限界上下文的程度决定了架构量子的大小和破坏性耦合的数量。
- “无服务”架构-BaaS(后端即服务)是那些明显或从根本上依赖于第三方应用或云端服务的应用、FaaS(功能即服务)
演进式数据:
- 是经过检验的、版本化的和增量的
- 架构师必须考虑应用的所有耦合特征,其中包括类、包/ 命名空间、库、框架、数据库模式,以及事务上下文。在架构演进时,忽视其中任一维度(或维度间的交互)都将产生问题。
- 在将单体架构迁移到某种更精细的架构时,应该从分离少量较大的服务开始。当构建一个全新的微服务架构时,开发人员应该尽量限制服务和数据上下文的大小。然后,不要仅按字面意思来理解微服务,对每个服务而言,小并不是必需的,能捕获有用的限界上下文才是关键。
- 数据的年龄和质量,识别真正有用的数据并将其保留下来,将旧数据作为参考但不将其纳入演进式开发的主流。
构建可演进的架构:
-
演进机制-通过下面三步来构建演进式架构
识别受演进影响的架构维度、为每个维度定义适应度函数、使用部署流水线自动化适应度函数 -
赋予现有架构演进能力取决于三个因素:组件耦合度、工程实践成熟度,以及开发人员构建适应度函数的难易程度。
-
团队可以通过多种划分方式将单体应用分解成服务。业务功能分组、事务边界、部署目标
-
演进模块间的交互-拆分共享的依赖、通过JAR文件共享依赖、复制共享的库以消除耦合点。共享就是耦合的一种形式,在微服务架构中这是非常不可取的
-
演进式架构构建指南-去除不必要的可变性、让决策可逆、演进优于预测、构建防腐层、服务模板、构建可牺牲架构、应对外部变化,传递依赖管理被视为有害的、更新库与更新框架、持续交付优于快照、服务内部版本化
-
演进式架构的陷阱和反模式-
为供应商为王反模式-无论从技术还是从业务流程的角度来看,将外部工具或框架置于架构的核心会严重限制架构的演进能力 -
陷阱:抽象泄漏 底层抽象破坏会导致意外的灾难,即原始抽象泄漏,它是技术栈日渐复杂带来的副作用之一。
-
反模式:最后10%的陷阱 在抽象范围的另一端存在着另一种复用陷阱,它隐藏在套装软件、平台和框架中。
-
反模式:代码复用和滥用-开发人员为实现可复用所添加的钩子越多,对代码的基本可用性损害越大。
-
微服务避免代码复用,遵循重复优于耦合的理念。
-
当耦合点妨碍了演进或其他重要的架构特征时,通过分叉或重复来打破耦合点。
架构师必须持续评估架构特征的适应度,保证它们仍在提供价值,避免沦为反模式。 -
陷阱:简历驱动开发 不要为了架构而构建架构,构建架构是为了解决问题。在选择架构前,要始终理解问题域,不要本末倒置。
-
增量变更 反模式:管理不当
-
当开发人员构建单体架构时,管理决策将影响所有项目。因此,在选择数据库时,架构师必须了解每个项目需要的能力,并考虑最复杂的情况。
-
陷阱:发布过慢 ,一个项目的生产周期决定了架构的演进速度。换句话说,演进速度和生产周期成正比
-
业务问题 陷阱:产品定制 为每个客户定制、永久的功能开关、产品驱动定制化
-
反模式:报表
-
陷阱:规划视野
实践演进式架构:
- 以领域为中心的团队应该是全功能的,这意味着每个项目角色都由该项目组成员承担
- 架构师设计架构来消除不当耦合,以简化增量变更。、全功能团队的目标之一便是消除协调摩擦
- 围绕业务能力组织团队:按照业务能力而非职能来组织团队
- 产品高于项目
- 团队成员间的连接数:尽量减少开发团队之间的连接数。
- 团队的耦合特征-文化、事不过三,三则重构
- 试验文化-从外部吸收想法、鼓励明确的改进、进行探针试验并稳定下来、创造创新时间、采用基于集合的开发方式、连接工程师和最终用户
- 公司为何决定构建演进式架构
可预测性与可演进性、规模、高级业务能力、以生产周期为业务指标
相关文章:
演进式架构
演进能力是一种元特征和保护其他所有架构特征的架构封装器IEEE 的软件架构定义中的41 视图模型。它关注不同角色的不同视角,将整个系统划分成了逻辑视图、开发视图、进程视图和物理视图架构师确定了可审计性、数据、安全性、性能、合法性和伸缩性是该应用的关键架构…...

OCP China Day 2023:五大社区齐聚,加速开源开放创新与落地
8月10日,2023年开放计算中国社区技术峰会(OCP China Day 2023)在北京举行。智慧时代,计算多元化、应用多样化、技术复杂化正驱动数据中心新一轮变革,开源开放社区已成为推动数据中心持续创新的重要力量,通过…...

【Linux】进程间通信之管道
【Linux】进程间通信之管道 进程间通信进程间通信目的进程间通信的方式 管道(内核维护的缓冲区)匿名管道(用于父子间进程间通信)简单使用阻塞状态读写特征非阻塞状态读写特征 匿名管道特点命名管道 匿名管道与命名管道的区别 进程…...
记录一个正则表达式
正则表达式要求如下: 至少 8 个字符; 至少包含一个小写英文字母; 至少包含一个大写英文字母; 至少包含一个数字; 至少包含一个特殊字符,特殊字符为:“!#$%^&*()-” 中的一个; 不包含2个连续…...

用于全局复根和极点查找算法的自适应网格生成器(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
修改Linux中SSH的端口
文章目录 修改Linux中SSH的端口Linux中默认的ssh端口关闭SELinux测试新端口 修改Linux中SSH的端口 Linux中默认的ssh端口 使用root用户操作 修改前先备份ssh_config cp /etc/ssh/sshd_config /etc/ssh/sshd_config_date "%Y%m%d%H%M%S"修改配置文件,找…...

Ansible从入门到精通【六】
大家好,我是早九晚十二,目前是做运维相关的工作。写博客是为了积累,希望大家一起进步! 我的主页:早九晚十二 专栏名称:Ansible从入门到精通 立志成为ansible大佬 ansible templates 模板(templa…...

国企的大数据岗位方向的分析
现如今大数据已无所不在,并且正被越来越广泛的被应用到历史、政治、科学、经济、商业甚至渗透到我们生活的方方面面中,获取的渠道也越来越便利。 今天我们就来聊一聊“大屏应用”,说到大屏就一定要聊到数据可视化,现如今…...

【MySQL--->数据类型】
文章目录 [TOC](文章目录) 一、数据类型分类二、整型类型三、bit(位)类型四、float类型五、decimal类型六、char和varchar类型1.char类型2.varchar3.char与varchar的区别 七、日期与时间类型八、enum和set 一、数据类型分类 二、整型类型 数值类型有数据存储上限,而且每个类型都…...

Ceph部署
一、存储基础 1)单机存储设备 ●DAS(直接附加存储,是直接接到计算机的主板总线上去的存储) IDE、SATA、SCSI、SAS、USB 接口的磁盘 所谓接口就是一种存储设备驱动下的磁盘设备,提供块级别的存储 ●NAS(…...
打工日记-Vue3+Ts二次封装el-table
el-table是elementUI中的表格组件,在后台把管理系统中,也是一个比较常用的组件,目前有一个比较好的开源项目ProTable,这个项目做的很好,集成了搜索,表格,分页器功能很强大。但在我的实际使用中也…...

funbox3靶场渗透笔记
funbox3靶场渗透笔记 靶机地址 https://download.vulnhub.com/funbox/Funbox3.ova 信息收集 fscan找主机ip192.168.177.199 .\fscan64.exe -h 192.168.177.0/24___ _/ _ \ ___ ___ _ __ __ _ ___| | __/ /_\/____/ __|/ __| __/ _ |/ …...

springcloud3 hystrix实现服务降级,熔断,限流以及案例配置
一 hystrix的作用 1.1 降级,熔断,限流 1.服务降级: A方案出现问题,切换到兜底方案B; 2.服务熔断:触发规则,出现断电限闸,服务降级 3.服务限流:限制请求数量。 二 案例…...

ComponentOne Studio ASP.NET MVC Crack
ComponentOne Studio ASP.NET MVC Crack FlexReport增强功能 添加了对在Microsoft Windows上部署Microsoft Azure的支持。 添加了对显示嵌入字体的支持。 .NET标准版的经典C1PDF(Beta版) GrapeCity的经典C1Pdf库现在提供了基于Microsoft.NET标准的版本。在任何.NET应用程序(包括…...
OPENCV C++(十一)
鼠标响应函数 //鼠标响应函数 void on_mouse(int EVENT, int x, int y, int flags, void* userdata) {Mat hh;hh *(Mat*)userdata;switch (EVENT){case EVENT_LBUTTONDOWN:{vP.x x;vP.y y;drawMarker(hh, vP, Scalar(255, 255, 255));//circle(hh, vP, 4, cvScalar(255, 255…...
ES使用心得
客户端 Transport Client已经快要废弃了,官方推荐使用High Level REST Client。 常用命令 启停 systemctl start elasticsearch systemctl stop elasticsearch节点状态 curl http://myservice1:9200/_cat/nodes?vip heap.percent ram.percent cpu l…...

Stable Diffusion - 幻想 (Fantasy) 风格与糖果世界 (Candy Land) 人物提示词配置
欢迎关注我的CSDN:https://spike.blog.csdn.net/ 本文地址:https://spike.blog.csdn.net/article/details/132212193 图像由 DreamShaper8 模型生成,融合糖果世界。 幻想 (Fantasy) 风格图像是一种以想象力为主导的艺术形式,创造了…...
部署K8S集群
目录 一、环境搭建 1、准备环境 2、安装master节点 3、安装k8s-master上的node 4、安装配置k8s-node1节点 5、安装k8s-node2节点 6、为所有node节点配置flannel网络 7、配置docker开启加载防火墙规则允许转发数据 二、k8s常用资源管理 1、创建一个pod 2、pod管理 一、…...

在时间和频率域中准确地测量太阳黑子活动及使用信号处理工具箱(TM)生成广泛的波形,如正弦波、方波等研究(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

一百五十四、Kettle——Linux上安装Kettle9.3(踩坑,亲测有效,附截图)
一、目的 由于kettle8.2在Linux上安装后,共享资源库创建遇到一系列问题,所以就换成kettle9.3 二、kettle版本以及安装包网盘链接 kettle9.3.0安装包网盘链接 链接:https://pan.baidu.com/s/1MS8QBhv9ukpqlVQKEMMHQA?pwddqm0 提取码&…...

《通信之道——从微积分到 5G》读书总结
第1章 绪 论 1.1 这是一本什么样的书 通信技术,说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号(调制) 把信息从信号中抽取出来&am…...

用机器学习破解新能源领域的“弃风”难题
音乐发烧友深有体会,玩音乐的本质就是玩电网。火电声音偏暖,水电偏冷,风电偏空旷。至于太阳能发的电,则略显朦胧和单薄。 不知你是否有感觉,近两年家里的音响声音越来越冷,听起来越来越单薄? —…...

使用Spring AI和MCP协议构建图片搜索服务
目录 使用Spring AI和MCP协议构建图片搜索服务 引言 技术栈概览 项目架构设计 架构图 服务端开发 1. 创建Spring Boot项目 2. 实现图片搜索工具 3. 配置传输模式 Stdio模式(本地调用) SSE模式(远程调用) 4. 注册工具提…...
uniapp 字符包含的相关方法
在uniapp中,如果你想检查一个字符串是否包含另一个子字符串,你可以使用JavaScript中的includes()方法或者indexOf()方法。这两种方法都可以达到目的,但它们在处理方式和返回值上有所不同。 使用includes()方法 includes()方法用于判断一个字…...

TSN交换机正在重构工业网络,PROFINET和EtherCAT会被取代吗?
在工业自动化持续演进的今天,通信网络的角色正变得愈发关键。 2025年6月6日,为期三天的华南国际工业博览会在深圳国际会展中心(宝安)圆满落幕。作为国内工业通信领域的技术型企业,光路科技(Fiberroad&…...

抽象类和接口(全)
一、抽象类 1.概念:如果⼀个类中没有包含⾜够的信息来描绘⼀个具体的对象,这样的类就是抽象类。 像是没有实际⼯作的⽅法,我们可以把它设计成⼀个抽象⽅法,包含抽象⽅法的类我们称为抽象类。 2.语法 在Java中,⼀个类如果被 abs…...

麒麟系统使用-进行.NET开发
文章目录 前言一、搭建dotnet环境1.获取相关资源2.配置dotnet 二、使用dotnet三、其他说明总结 前言 麒麟系统的内核是基于linux的,如果需要进行.NET开发,则需要安装特定的应用。由于NET Framework 是仅适用于 Windows 版本的 .NET,所以要进…...
深入理解 React 样式方案
React 的样式方案较多,在应用开发初期,开发者需要根据项目业务具体情况选择对应样式方案。React 样式方案主要有: 1. 内联样式 2. module css 3. css in js 4. tailwind css 这些方案中,均有各自的优势和缺点。 1. 方案优劣势 1. 内联样式: 简单直观,适合动态样式和…...
6.计算机网络核心知识点精要手册
计算机网络核心知识点精要手册 1.协议基础篇 网络协议三要素 语法:数据与控制信息的结构或格式,如同语言中的语法规则语义:控制信息的具体含义和响应方式,规定通信双方"说什么"同步:事件执行的顺序与时序…...

数据挖掘是什么?数据挖掘技术有哪些?
目录 一、数据挖掘是什么 二、常见的数据挖掘技术 1. 关联规则挖掘 2. 分类算法 3. 聚类分析 4. 回归分析 三、数据挖掘的应用领域 1. 商业领域 2. 医疗领域 3. 金融领域 4. 其他领域 四、数据挖掘面临的挑战和未来趋势 1. 面临的挑战 2. 未来趋势 五、总结 数据…...