软件架构设计理论
2021-10-21 17:40:04 2 举报
AI智能生成
软件架构设计理论
作者其他创作
大纲/内容
ABSD基于架构的软件开发
What
企业级需求的决策体现
业务功能需求、用例
质量属性、肺功能需求
企业限制、架构策略
ABSD方法论
功能分解
(自顶向下功能分解)使用已有的基于模块的内聚和耦合技术
高内聚
低耦合
选择架构风格
选择架构风格来实现质量和业务需求
定义软件模板
描述软件元素在共享服务和底层构造的基础上,如何进行和交互
递归迭代
清洗定义迭代的每一个步骤
Why
架构的真正驱动
功能需求和用例
质量和非功能需求
限制和企业策略
How
ABSD具体实现
架构需求
(需求库)需求获取
标识构件
生成类图
对类进行分组
将类打包成构件
需求评审
架构设计
提出架构模型
映射构件
分析构件相互作用
产生架构
设计评审
架构文档化
架构复审
复审后的文档化架构
架构实现
构件库
分析与设计
构件实现
构件组装
构件测试
架构演化
需求变化归类
构件库
架构演化计划
构件变动
更新构件的相互作用
架构组装和测试
技术评审
演化后的架构
案例分析
证券业务架构
业务背景
银行海外分行拿到证券牌照
功能需求
红马甲交易、网银查询、分红派息T+1结算、银行监管核算
肺功能需求
99.95%高可用
银行遇到新的挑战-证券业务
渠道层
网银、交易所前置
领域层
日间交易模块、共享数据库、夜间批处理模块
内部渠道层
交易监管网关、交易核算网关
银行核心层
整合交易大型机
题目1:对于新业务,如何完成一个完整的架构设计流程?
题眼
架构设计方法论(如ABSD的需求、设计、文档化、复审、实现、演化)
加分项
能将设计原则、架构风格和演化过程描述清楚
题目2:如何在架构设计中选择合适的软件风格和软件模板?
题眼
需求驱动论(功能、质量、限制)
加分项
能结合实际项目,描述如何根据需求选择风格和模板
题目3:在一个订单输入子系统中,创建新订单和更新订单都需要核查用户账号是否正确。
用例“创建新订单”、“更新订单”与用例“核查客户账号”之间是什么关系?
用例“创建新订单”、“更新订单”与用例“核查客户账号”之间是什么关系?
题眼
理解“包含”、“扩展”、“泛化”等基本关系
加分项
能结合UML图来描述和分析
DSSA特定领域的软件架构开发
What
目标场景
DSSA方法论 – 特定问题域的应用模型
DSSA基本活动
领域分析
建立领域模型
领域分析方法
领域分析图
领域设计
获得DSSA、
领域实现
开发和组织可复用信息
DSSA人员分工
领域专家
产品经理-需求规约、领域字典
领域分析人员
系统分析员、产品经理、企业架构师
领域设计人员
应用架构师、自身程序员-软件重用和领域设计
领域实现人员
老带新模式
Why
领域具有普遍性、抽象性、重用性
领域分析
领域设计
DSSA创建过程
定义领域范围
定义领域特定的元素
定义领域特定的设计和实现需求约束
定义领域模型的架构
产生、搜集可服用的产品
三层环境模型
领域开发环境
领域特定的应用开发环境
应用执行环境
How
分析、设计、实现、迭代
领域实现
搜索可复用元件
产生可复用元件
进一步升华-螺旋形迭代
案例分析
国际电商平台架构
票务领域分析方法
领域分析
领域分析的输入
技术文献
成型软件
用户-铁杆粉丝
专家建议-退役球员
未来需求-合作球队
方式
管理机制
领域方法-事件风暴
人员配置
领域实现人员-老中青
领域设计人员-应用架构
领域分析人员-其他架构
领域专家人员-产品经理
领域分析的输出
分类方法-子域分层
标准(质量、约束)
功能模型(类图、ER图)
领域语言
票务领域分层
通用支撑子域
数据平台
数据仓库
数据湖
数据广告
数据科学
机器学习
数据模型
训练、预测
负载管理
API网关
设限
CDN
内容管理
广告
内容
消息通告
短信
微信
通告
消息
基础架构
VPC
云服务
应用平台
搜索
作业
消息队列
质量保证
合并
测试
自测
集成发布
测试
发布
遥测监控
日志
链路追踪
合规审计
法务要求
核心子域
购买
支付
履约
供票
市场
风控
客服
发现
对账
产品
定价
题目1:请描述一下你在大型架构设计中的职责,以及如何和其他部门同事配合的?
题眼
人员分工
架构师沟通
架构师职责
组件和决策
加分项
能结合特性方法论(ABSD、DSSA、AT等)
题目2:请描述一下对于领域架构的理解
题眼
领域驱动模型
DSSA领域架构开发方法
加分项
能将业务映射到领域,并能复用现有的架构元件
题目3:请描述一下你们公司的业务模型
题眼
领域驱动模型,本公司核心域DSSA软件架构
加分项
能将所在行业的领域DSSA软件架构解释清楚
题目4:风向一个你用过的领域相关的架构设计方法,对比一下和DSSA的思路有什么不同?在不同场景下应该如何取舍更合适?
AT架构思维
What
AT方法论
需求驱动
组件模型
功能性需求(用例说明)
运行模型
非功能性需求(质量)
非功能性需求(限制)
多视角
架构立方体
z轴应用、技术选择
x轴逻辑、物理实现
Z轴功能、运行模型
使用场景
认证考试
OpengGroup认证
软考
面试
方法论分享
画图环节
试用期
快速理解公司架构
快速开展项目设计
快速开展项目迭代
Why
真正可以和UML模型语言、RUP统一过程对接的方法论
对接UML模型语言
对接RUP统一过程
How
先看一个案例
电力行业案例
需求文档-质量
多维度架构设计
降低维度
题目1:你在架构设计中通常采用什么方式来描述软件架构
题眼
视角与视图
加分项
能结合实际案例,分析多视角架构设计思路
题目2:你在架构设计中采用什么方式来描述需求?
题眼
用例与质量场景
加分项
能结合实际案例,分析如何妥协用例和质量要求
软件架构概念
软件架构的定义
What
软件架构的定义和两派之争
少林-组成派
组件组成
代码包
模块
领域
CBM
SOA
软件系统架构
就是描述计算组件与组件的交互
架构设计
拆解
定义
关联
画图与实现
架构图举例
武当-决策派
决策山上有真人
架构的真谛是架构决策,是智慧和思维
软件系统架构
是由一个个决策组成的有机整体
架构设计
根据需求
限制决定技术
架构和实现
架构图举例
架构设计大师
BA大师
元素
接口
子系统
协作
风格
P大师(鲁棒图)
处理元素
数据元素
连接元素
W大师
决策
方向
过程
个人观点
组件是眼
决策是手
软件架构目的
Why
案例:IT界的莫扎特
桥梁
从“产品”听众获取灵感
指引
指引“研发”乐队完成演奏
分割
将长篇大作切割成乐章
交互
将乐章和声部交叠协奏
决策
在思考中挣扎,在决策中完美
演进
G小调第40交响乐-悲凉中前进
软件架构的发展阶段
How
软件架构的过去
语言
C
Java
Python
Go
结构设计
数据结构
设计模式
算法
统一建模
UML
CBM
软件架构的现在
多视角
逻辑
物理
应用
技术
功能
部署
体系架构
ABSD
DSSA
AT
软件架构的未来
云化-资产复用
IaaS
PaaS
SaaS
演进式架构
拆迁者
修缮者
绞杀者
题目1:日常工作主要有哪些?
题眼
工作广度
组成与决策
莫扎特的6大作用
加分项
方法论完整
新架构框架
新技术框架
题目2:作为架构师,有什么推崇的书或者大师?
题眼
学习能力
知识系统
加分项
体系书籍
新技术书籍
大师互动分享
题目3:你在架构设计过程中碰到的难点?
题眼
案例深度
决策派思路
从莫扎特6大作用出发
加分项
决策依据
理论->实际->理论
软件架构理论
设计决策的体现
系统设计的约束条件
组织结构的映射
DevOps的实现
循序渐进的演进手段
可传递可复制的模型
What
架构落地的保障
业务
跟随业务发展、扫清技术债务
架构
架构向前演进、向后兼容
技术
技术成熟度、复杂度、买还是建
“架”起到需求到落地的桥梁
“构”建IT新蓝图
一个电商的实际例子(早期)
应用关联:意大利面
软件发布:跑火车
一个电商的实际例子(中期)
CDN缓存
蓝绿部署、
一个电商的实际例子(后期)
云平台
弹性扩缩容
云存储
批处理
调度
大数据平台
Why
沟通
项目干系人的沟通交流的手段
交流在哪里?
语境不同
通用语言
Ubiquitous language
Ubiquitous language
技术专家
领域专家
沟通配合
立场不同
决策依据
依据原因
渠道失真
决策派,一堆人来进行决策
召集所有人,防止单向沟通
决策
SWOT分析
优势
全世界第一款省下100万广告费用
劣势
需要研发手机壳套探测器,软硬件开发费用预估1000万
机会
打入粉丝群,捕获无脑脸控
威胁
有被XXX抄袭的风险
Mesos Marathon SWOT分析
优势
资源统一管理,多架构并存,快速上手,部署比较快
劣势
不适合混合云,文档相对较少,功能覆盖不全
机会
云大数据融合,新的调度架构
威胁
风口变化,K8S江山一统
Kubernetes SWOT缝隙
优势
混合云模式,技术普及率,存储管理,弹性伸缩
劣势
仅为容器服务,安装相对复杂,大数据场景
机会
江山一统,业界标准
威胁
风口变化,Serverless
RASCI决策矩阵
按照数列拆分任务
负责人拆分
拆分到小组
拆分到人
R-执行人,A-负责人,S-支持者,C-顾问,I-知情人
约束
ADMEMS矩阵
RAID矩阵
系统质量属性
质量核心
五点核心
性能
可用性
扩展性
安全性
耦合性
相关核心
易用性
伸缩性
可移植性
可维护性
非核心
可操作性
可重用性
组织
组织结构的映射
康威定律
第一定律
There is never enough time to do something right, but there is always enough time to do it over
时间再多一件事情也不可能做的完美,但总有时间做完一件事情
时间再多一件事情也不可能做的完美,但总有时间做完一件事情
对于复杂的,需要协作完成的系统开发,沟通是必须要持续提升的问题。
每个团队由5-10人组成(沟通成本 = n(n-1)/2 - 《人月神话》),在团队内部进行频繁的、细粒度的沟通。对于团队外部,定义好接口,契约,只进行粗粒度的沟通。这样可以降低沟通成本,同时也符合高内聚,低耦合原则(代码和人员管理有些时候真是相通的)。
每个团队由5-10人组成(沟通成本 = n(n-1)/2 - 《人月神话》),在团队内部进行频繁的、细粒度的沟通。对于团队外部,定义好接口,契约,只进行粗粒度的沟通。这样可以降低沟通成本,同时也符合高内聚,低耦合原则(代码和人员管理有些时候真是相通的)。
第二定律
There is a homomorphism from the linear graph of a system to the linear graph of its design organization
线型系统和线型组织架构间有潜在的异质同态特性
线型系统和线型组织架构间有潜在的异质同态特性
这就是我们在用kanban管理迭代时几乎都有一列是BAU(Business As Usual ),其中会包括一些日常修复的Bug Story。敏捷开发中将迭代引入,做到持续交付,快速验证,迅速反馈,持续改进。
第三定律
There is a homomorphism from the linear graph of a system to the linear graph of its design organization
线型系统和线型组织架构间有潜在的异质同态特性
线型系统和线型组织架构间有潜在的异质同态特性
大白话就是,你想要架构成为什么样,就将团队分成怎样的结构。比如前后端分离的团队,架构就是基于前后端分离。在基于微服务设计的团队里,一个很好的理念是自管理。团队内部对于自己所负责的模块高度负责,进行端对端的开发以及运维。
第四定律
The structures of large systems tend to disintegrate during development, qualitatively more so than with small systems
大的系统组织总是比小系统更倾向于分解
大的系统组织总是比小系统更倾向于分解
合久必分,分久必合,团队以及架构都是在不断优化的。一个团队随着人员的增加,沟通以及管理成本一定会增加。
贝佐斯的两个披萨原则
“两个披萨原则”有助于避免项目陷入停顿或失败的局面。领导人需要慧眼识才,找出能够让项目成功的关键人物,然后尽可能地给他们提供资源,从而推动项目向前发展。让一个小团队在一起做项目、开会研讨,更有利于达成共识,促进企业创新。
演进
拆迁者模式
保留原有的迁移到新的位置,很难实施,直接重构
绞杀者模式
被寄生者死亡,寄生者替代存活
修缮者模式
追加新的功能,逐步替换,一直到全部替换完成位置
适应度函数
原子vs整体适应度函数
触发式vs持续式适用度函数
静态vs动态适应度函数
自动vs手动适应度函数
临时vs预设适应度函数
复用
方法论复用
ABSD、DSSA、AT、EA、TOGAF
模型复用
UML、SOA、CBM
工件复用
素材、图片、表格、图标、文件
剪裁
三七原则,保留30%就很高了
资产更新
内部资产库、外部架构社区
How-案例分享
DevOps凤凰传奇
如何解决环境问题
开发、OA和生产的不匹配
如何解决耦合问题
凤凰项目和传统系统耦合
如何解决资源共拥问题
关键人员疲于再多个项目中切换
如何满足峰值需求
突发性业务需求、性能测试需求
如何解决安全问题
最小代价完成安全合规审计
OpenGroup认证
或者国内的软考高级架构都是一样的
TOGAF企业架构
广度
知识点
案例分析
笔试
Master Architect主架构师认证
应用架构
数据架构
集成架构
技术架构
考试过程
三个完整方法论案例
需求
设计
风险
决策
解决
20+架构师评测点(各2-3个案例论证)
评测重点:方法论、模型的复用,架构资产的贡献
题目1:作为架构师,遇到部门冲突如何解决?
题眼
决策派
语境、立场、沟通渠道处理,架构决策
加分项
方法论完整
通用语言
RASCI决策
SWOT分析
题目2:作为架构师,平时的设计重点关注哪些因素?
题眼
质量
扩展性
性能
可用性
安全性
耦合度
加分项
多角度分析
实际案例侧重点清洗
题目3:作为架构师,如何处理新架构和老架构之间的冲突?
题眼
解决技术债务
架构演进策略
加分项
多模式使用(拆迁、修缮、绞杀)
冲突预防
题目4:作为架构师,挑选一个你的实战项目,,描述该应用架构如何随着组织架构的变化而演进的?
题目5:挑选一个项目,描述项目中你如何挑选、复用和剪裁合适的架构设计架构、设计模式、架构风格、软件包?
案例分析
DevOps凤凰项目
OpenGroup架构师认证
证券业务案例
国际电商平台案例
电力行业案例
软件架构风格
What
主流软件架构风格
数据流风格
数据流
Data Flow
Data Flow
批处理
Batch Sequential
Batch Sequential
强时间顺序
只有当前一步的计算任务处理完成后,后一步处理才能开始。计算任务前后顺序明确。
强完整性
数据传送在计算单元之间通过指定的数据交互方式传递。每一步要确保数据完整,才可以向下一步发起数据传送。
强控制力度
有独立的顺序控制和时间把控机制,并辅以数据检查等功能。
经典案例
传统定制批处理任务
比如银行的夜间批量结算和大小额清算,券商的夜间交易结算和证券系统对账等。特点是通常运行在指定时间,数据流庞大,每一步有精确的数据处理要求和校验机制,顺序逻辑清晰。
Hadoop大数据处理
Hadoop在处理过程中有明确的步骤安排,比如map几次,shuffle几次,再reduce完成数据处理。
Apache Beam大数据处理
当前比较火的批量处理工具是Apache Beam。虽然它同时支持批处理和流处理,但是在日常使用中其批处理的优势更加明显。它定义类专门的数据集、计算过程、管道和执行器。能够形成有向无环图,来保证数据流的方向和结果输出。
管道-过滤器
Pipes-Filters
Pipes-Filters
过滤器
是其中的核心构件,负责业务的处理。它从用户或者上游管道获得输入数据,进行数据的变换及增量计算,处理完成后,通过下游管道传递给另一个过滤器。过滤器是独立的实体,它不能与其他的过滤器共享数据,而且一个过滤器不知道它上游和下游的其他过滤器信息。
管道
是一种数据传输途径。可以是Unix/Linux操作系统的管道文件,也可以是消息队列,只要能确保数据的先进先出,单向进出就可以了。
经典案例
编译器
在编译器系统中,一个阶段(包括词法分析、语法分析、语义分析和代码生成) 的输出是另一个阶段的输入,处理阶段是是以数据流进行编译过程驱动流转的。
操作系统管道过程
比如经典的Linux命令"ps -ef|grep java",就是在系统中检查java进程信息,其中的”ps -ef“和”grep java“就是两个过滤器,各自处理相关流程步骤,中间的"|"标识,就是管道,负责在两个过滤器之间进行有向传输。
Streaming流处理
比如经典的Spark Streaming、Storm、Apache Flink、Kafka Streams等流式处理框架,或者是完整的流数据管道式处理方式,或者是将数
据流进行微小的窗口切分,再采用超小批量处理方式进行数据处理和向后传递。
据流进行微小的窗口切分,再采用超小批量处理方式进行数据处理和向后传递。
数据流两种风格的相似点
解耦
类似福特流水线的优势,它将每个阶段的处理过程进行了隔离,使得软件构件具有良好的隐蔽性和高内聚、低耦合的特点;
每个批处理过程或者过滤器独立管理,可以方便地进行替换。
每个批处理过程或者过滤器独立管理,可以方便地进行替换。
复用
支持软件重用,只要提供适合数据处理的需求,任何两个批处理过程和过滤器都可有序被连接起来。
高吞吐
数据流风格在5大风格中是最适合大数据的架构风格。它可以完成各种大量数据互通、传递、处理的过程。
同时,批处理序列风格与管道过滤器风格的不同点也很多:
计划性
批处理通常由时间规划和任务调度统筹安排;
而管道过滤器是递增式处理过程,是由数据驱动的处理流程。
而管道过滤器是递增式处理过程,是由数据驱动的处理流程。
敏捷性
批处理需要完成前序任务,再进行后续任务,通常整个任务处理周期较长,通常以分钟、小时、天为单位;
管道过滤器在传输过程中没有整体处理的概念,可以快速将一份小的数据变动流过相关的过滤器和管道,实现秒级、分钟级的快速响应。
管道过滤器在传输过程中没有整体处理的概念,可以快速将一份小的数据变动流过相关的过滤器和管道,实现秒级、分钟级的快速响应。
调用返回风格
调用-返回
Call Return
Call Return
主程序-子程序
Main Program-Subroutine
Main Program-Subroutine
主程序/子程序风格是面向过程的经典架构风格。
一般采用单线程控制,把问题划分为若干处理步骤,分别由主程序和子程序完成。
主程序调用子程序,子程序将调用结果返回给主程序。同时,子程序通常也可以合成为模块,增加调用过程的层次性。
主程序最终结果的正确性,取决于其下属的模块和子程序的执行结果。
一般采用单线程控制,把问题划分为若干处理步骤,分别由主程序和子程序完成。
主程序调用子程序,子程序将调用结果返回给主程序。同时,子程序通常也可以合成为模块,增加调用过程的层次性。
主程序最终结果的正确性,取决于其下属的模块和子程序的执行结果。
简单明了
符合传统的商业行为过程:浏览->添加购物车->购买->支付->收货->评价等。
架构清晰
可以和程序流图、泳道图、状态机模型等架构图一一对应,方便开发和验证。
面向对象
Object Oriented
Object Oriented
这种风格是主程序子程序风格的进化,它随时面向对象语言的产生而同步出现。
它将数据的表示方法和它们的相应操作封装在一个抽象数据类型或对象中。
由对象来负责保持资源的完整性(成员变量)和程序之间的过程调用关系(方法)。
它将数据的表示方法和它们的相应操作封装在一个抽象数据类型或对象中。
由对象来负责保持资源的完整性(成员变量)和程序之间的过程调用关系(方法)。
完整性
每个对象独立负责维护其本身的完整性,比主程序子程序的紧耦合方式,更容易实现应用体完整性。
隐蔽性
对象的表示对其他对象而言是隐蔽的,对象可以不影响它的客户就能改变其实现方法。
面向对象编程的优势
可以充分利用高级语言的优势来实现封装、聚合、继承、接口、多态、依赖、抽象、复用等特质。
和现实生活中的实体逻辑可以一一映射地进行实现。
和现实生活中的实体逻辑可以一一映射地进行实现。
层次结构
Layered
Layered
分层是软件架构设计的主流方法之一,将应用设计成一个层次系统,每一层为上层服务,并作为下层客户。
每一层最多只影响上下两层,同时允许每层可以用不同的方法来实现应用逻辑和功能。
这对于解决软件的复杂性和重用性,提供了强大的支持。
每一层最多只影响上下两层,同时允许每层可以用不同的方法来实现应用逻辑和功能。
这对于解决软件的复杂性和重用性,提供了强大的支持。
但它们有一个共同点,都采用了层次化的描述方式,所以可以 看成是层次结构风格的延伸。
邻居互动性
每一层至多和相邻的上下层交互,因此功能的改变最多影响相邻的上下层
隐藏复杂性
每一层可以独立设计、开发,只要满足和上下层的接口定义即可。 同一层可以实现架构重用和借鉴,从整体上将应用实现了分层解耦。
经典案例
OSI网络7层模型,TCP/IP网络4层模型
确保每一层可以采用不同的技术栈和设计思路,所有数据会根据网络层次结构进行数据包的封装,不会出现层次的跳跃现象。
操作系统内核和用户态管理
操作系统从核心的内核层,到外围的工具、用户系统,类似一个洋葱模型,层层包裹。所有的过程调用只在相邻两层之间进行
应用分层模型
比如MVC三层模型、领域驱动4层模型等。我们将在后续的领域 驱动章节详细介绍4层领域模型。
可以想见,层次结构风格极大化地抽象了软件架 构,摆脱了编程语言的限制。
其他如C/S、B/S、SOA应用架构等,横跨了软件、 系统和网络范畴。
可以想见,层次结构风格极大化地抽象了软件架 构,摆脱了编程语言的限制。
其他如C/S、B/S、SOA应用架构等,横跨了软件、 系统和网络范畴。
调用返回风格是5大架构风格中最润物细无声的一种。它几乎自然而然地被运用在了所有开发设计过程中:
在面向过程的开发中,通常都采用了主程序/子程序风格 在面向对象的开发中,几乎都是用了面向对象风格 在应用的分层设计中 几乎都采用了层次结构风格
在面向过程的开发中,通常都采用了主程序/子程序风格 在面向对象的开发中,几乎都是用了面向对象风格 在应用的分层设计中 几乎都采用了层次结构风格
独立构建风格
独立构件
Independent Components
Independent Components
主要强调系统中的每个构件都是相对独立的个体,他们之间不直接通信,以降低耦合度,提升灵活性
进程通信
Comm Processes
Comm Processes
目标明确
远程通信具有清晰的指向性,目标明确
同步为主
通常以同步调用为主,辅以异步交互式通信方式
经典案例
应用之间的RPC调用
通常采用同步或者异步方式,远程调用其他模块的接口程序
应用之间的RestAPI调用
通过规定的消息传输机制(REST接口规范)来实现同步或异步方式的进程间通信
点对点通信
比如区块链、BitTorrent等的点对点通信,也是进程通信风格的延伸
事件驱动的系统
Event Systems
Event Systems
事件驱动风格是基于事件的隐式调用风格,构件不直接调用一个过程,而是触发或者广播一个或者多个事件。
后续执行过程会被注册在一个或者多个事件,当对应的时间被触发或者广播时,系统会自动调用该事件中注册的过程,执行相应的模块功能。
后续执行过程会被注册在一个或者多个事件,当对应的时间被触发或者广播时,系统会自动调用该事件中注册的过程,执行相应的模块功能。
目标明确
远程通信具有清晰的指向性,目标明确
同步为主
通常以同步调用为主,辅以异步和交互式通信方式
隐式调用、匿名互动
事件的触发者并不知道哪些构建会被这些事件影响。
这样不能假定构件的处理顺序,甚至不知道哪些谷草恒会被调用,体现了极强的低耦合性
这样不能假定构件的处理顺序,甚至不知道哪些谷草恒会被调用,体现了极强的低耦合性
广播机制
通常事件驱动的接受者不止一个,会采用广播方式进行信息传输,方便实现一对多的过程调用和应用交互
经典案例
调试器
在IDE工具中设置断点,当触发断点后,IDE工具处理程序在断点出停下,变量监视器自动刷新变量数值。
整个过程IDE工具和调试模块之间没有直接的进程通信,而是采用事件驱动的机制实现过程调用。
整个过程IDE工具和调试模块之间没有直接的进程通信,而是采用事件驱动的机制实现过程调用。
消息队列
消息队列常用于应用间的通信和业务流的削峰填谷,当消息被发送到消息队列后,对应的消息监听会自动消费该消息,
并进行相应数据和业务处理操作。整个过程中消息的生产者和消费者之间没有直接的互动和了解,完全有消息队列来驱动数据流的指向。
并进行相应数据和业务处理操作。整个过程中消息的生产者和消费者之间没有直接的互动和了解,完全有消息队列来驱动数据流的指向。
事件驱动设计(后面DDD会介绍)
事件驱动设计(Event Driven Architecture)是当今很火的话题,结合CQRS读写分离等技术,可以实现完整的业务分解和设计。
可以是点对点的、制定方向的进程通信风格;
也可以是广播、饮食调用的时间驱动系统风格;
两者结合起来真正的实现了进程与进程、模块与模块、系统与系统之间的互动
也可以是广播、饮食调用的时间驱动系统风格;
两者结合起来真正的实现了进程与进程、模块与模块、系统与系统之间的互动
虚拟机风格
虚拟机
Virtual Machines
Virtual Machines
解释器
Interpreter
Interpreter
完整的解释工作的解释引擎、被解释代码的存储区、记录解释器引擎当前工作状态的数据结构、记录源码被解释执行进度的数据结构等。
解释器可以方针硬件的执行过程和一些关键应用,通常被用来弥和程序语义与硬件语义之间的差异,其缺点是执行效率低。
解释器可以方针硬件的执行过程和一些关键应用,通常被用来弥和程序语义与硬件语义之间的差异,其缺点是执行效率低。
虚拟环境
提供虚拟运行环境
程序解释
解释程序代码、运行状态等
经典案例
编程语言执行器
如Java语言的JVM。他负责Java语言的解释和虚拟机运行环境。
容器运行解释器
像Docker Daemon等容器运行环境,也可以理解为容器的解释器和虚拟机,完成了自定义容器内应用的解释和管理
CAD仿真环境
电路前端后端仿真运行环境,负责解释电路设计程序,并提供运行仿真环境
专家系统
基于经验的大数据推理步系统。将专家推理逻辑和程序,转换成决策平台的解释器系统。
基于规则的系统
Rule Based System
Rule Based System
基于规则的系统包括规则集、规则解释器、规则/数据选择器及工作内存等
规则决策
规则的细节被引擎所解释,来决定业务、监控等策略和措施的制定
人工智能
简化人工智能、加速自动化和逻辑处理
经典案例
业务规则引擎
像Drools开源规则引擎、IBM iLog商业规则引擎,都是业务人员的好伙伴。业务人员不能像程序员一样精通if/else逻辑开发,但是又需要可以随时进行业务逻辑的修改和优化。业务规则引擎提供了有效的途径,它可以采用图形化的方式,让业务人员拖拖拉拉地制定业务逻辑。比如优惠券的计算逻辑、产品的价格制定逻辑、仓储系统的内部流转逻辑等
大数据分析引擎
大数据分析通常满足八二原则,80%的数据分析仍然是有规律可循,可以采用一定的规则引擎来处理,另外的20%数据才需要AI人工智能的强大分析能力来完成。在规则话的处理过程中,通常数据科学家不会直接编程来完成逻辑规则的指定,所以大数据环境,分析规则引擎也被广泛使用,来协助数据工程和数据分析
网络防护系统
比如WAF应用防火墙、机器人识别防护、IDS/IPS入侵检测和防御,通常都依赖于规则的设定
运维自动化
在IT运维和数据中心运维中,越来越多的采用了规则类的工具和系统来实现自动化
虚拟机风格是偏重运行环境的一种风格。她描述了在一个应用系统中,程序里面是如何被解决和用于决策的:
虚拟机方式提供解释引擎和中间数据存储过程
规则引擎来匹配和解释规则集,指定最终决策
虚拟机方式提供解释引擎和中间数据存储过程
规则引擎来匹配和解释规则集,指定最终决策
仓库风格
仓库
Repository
Repository
别名也叫作以数据为中心的风格,可见它关注的重点是数据的存储和共享方式。
仓库有两个核心构件:中央数据单元和独立构件。
中央数据单元存储和管理所有数据和系统当前状态;独立构件通过和中央数据存储交互,来执行逻辑处理
仓库有两个核心构件:中央数据单元和独立构件。
中央数据单元存储和管理所有数据和系统当前状态;独立构件通过和中央数据存储交互,来执行逻辑处理
数据库
DataBase
DataBase
数据库架构师仓库风格常见的形式,所有的关系型和非关系型数据库都可以归为这一风格。
它有一个中央数据库或者数据仓库,作为数据共享数据源,保存当前系统的数据状态;
大量的风不是和不同业务逻辑的系统,作为独立处理元素,对数据元素进行操作
它有一个中央数据库或者数据仓库,作为数据共享数据源,保存当前系统的数据状态;
大量的风不是和不同业务逻辑的系统,作为独立处理元素,对数据元素进行操作
共享数据源
集中式的共享数据库
独立处理单元
分布式的独立处理节点
超文本系统
Hypertext System
Hypertext System
超文本系统风格主要用于共享静态网页
多重共享形式
超文本系统可以是集中的文件资源方式,也可以是网状互通的分布式资源共享方式
非结构化文件
适合管理非结构化文件,入静态文件、对象存储等
经典案例
CMS内容管理系统
保存有JS、CSS、Html的话静态网页,用于让不同领域的前端节点来共享的访问静态页面元素和架构
分布式文件互通
节点个子存储部分文档,通过节点跳跃、网状链接等方式共享静态文件
黑板
Blackboard
Blackboard
黑板是所有软件架构风格里最复杂的一套风格。通常只在特定领域使用,比如语音识别、模式识别、信号处理等。
黑板系统是一种问题求解模型。以语音识别为例,通常一段语音的识别没有必然正确的最优解,只有根据现有知识和模型的匹配近似解。将原有问题通过变换、分割等方式转换为多个子问题,并将原始数据也相应地转换为高级数据结构。1000个人心中有1000个哈姆雷特,同样地,1000个专家(或专家系统)也会有1000个不同的子问题解。用一个黑板,让这些专家将已经获得的信息、已经处理完的数据、已经完成的子问题都写到同一个黑板上。其他专家可以通过这个共享的黑板的数据变更,很快地作出反应,优化自己手上的子问题计算。
这个黑板,就是用于记录组织推理步骤、控制状态数据和问题求解之领域知识的框架。它将问题的解空间组织成一个或多个应用相关的分级结构。这些分级结构将由不同的专家(系统),通过不同知识表达方法、推理框架和控制机制的组合来形成各自的知识源。知识源之间没有直接的数据传输,所有交互都通过共享的黑板的数据更新来完成。
分布式知识源
不同的子问题采用不同的数据集、推理框架和控制机制,生产分布式的知识源。
集中式的数据共享
通过黑板这个集中式逻辑系统完成所有知识源的数据共享
集中式控制
通过黑板的数据更新,通知各数据源,从而驱动分布式计算的进行
仓库风格是5大架构风格中,最偏重数据共享的一种风格。它描述了在一个应用系统中,数据是如何被分布式系统所存储和访问的:
数据库风格做通用的数据集中式共享方式。
超文本系统用于静态文件的共享。
黑板用于信号处理等特殊领域的知识源的共享,和子问题解的流程驱动。
数据库风格做通用的数据集中式共享方式。
超文本系统用于静态文件的共享。
黑板用于信号处理等特殊领域的知识源的共享,和子问题解的流程驱动。
Why
风格影响架构质量和实现效率
How
理论结合面试题实战
题目1:Windows操作系统在图形用户界面处理方面采用的核心架构风格是什么风格?
题眼
理解“事件驱动”软件架构风格
加分项
能结合注册事件处理和回调函数进行深入分析
题目2:Java语言宣传“一次吧编写,到处运行”的特性,从架构风格上看符合什么风格特点
题眼
理解“虚拟机”软件架构风格
加分项
能结合Java解释型语言、JVM原理,进行深入分析
题目3:如果要开发一个web服务端处理软件,对客户端请求消息进行解析与处理,包括HTTP报头分离、SOAP报文解析等功能。
采用什么架构风格,最合适该服务端处理软件
采用什么架构风格,最合适该服务端处理软件
题眼
理解“管道-过滤器”软件架构风格
加分项
能结合Web服务器在数据传输上的协议分层原理,进行深入分析
讨论题目1:
某公司承接了一个开发家用空调自动调温器的任务,调温器测量外部空气温度,根据设定的期望温度控制空调的开关。根据该需求,你认为公司应采用哪种架构风格最为合适
某公司承接了一个开发家用空调自动调温器的任务,调温器测量外部空气温度,根据设定的期望温度控制空调的开关。根据该需求,你认为公司应采用哪种架构风格最为合适
讨论题目2:
某游戏公司欲开发一个大型多人即时战略游戏,游戏设计的目标之一是能够支持玩家自行创建战役地图,定义游戏对象的行为和之间的关系。针对该目标,公司应该采用架构风格最为合适?
某游戏公司欲开发一个大型多人即时战略游戏,游戏设计的目标之一是能够支持玩家自行创建战役地图,定义游戏对象的行为和之间的关系。针对该目标,公司应该采用架构风格最为合适?
0 条评论
下一页