怎样理解:业务架构、应用架构、数据架构、技术架构与系统和复杂度 ...

打印 上一主题 下一主题

主题 809|帖子 809|积分 2437

关于系统的理解

   1.1 系统的概述

随着人类社会的发展,人们面临越来越多的规模巨大、关系复杂、参数众多地复杂题目,这些题目的复杂度已经远远超出人类的理解能力,系统论就是为了分析和解决这些题目而生。我们平时接触的计算机系统包括软件系统,本质上属于系统论的一个范畴。系统论是一门独立的学科,经历了多年的发展已经形成了体系化的理论。系统论里的一些原则、理论、方法同样适用于计算机系统,计算机系统里遇到的复杂性题目在系统论里肯定会有原则性的引导。相信前人肯定比我们聪明,我们遇到的题目,前人肯定也遇到过,只不过以另外一种形式呈现。多年的互联网从业履历很轻易让我们拘泥于互联网软件系统,如许很轻易忽略更一样平常性的规律和原理。

以是,把互联网软件系统放到软件系统里看,把软件系统放到系统论里看。

从计算机系统出来,进入系统论的层面,再回到计算机系统。这种思维的切换,仿佛天主视角与人间视角的来回切换。

关于系统定义:系统由相互作用和相互依赖的多少组成部门联合成的、具有特定功能的有机团体。系统论强调团体与局部、局部与局部、系统本身与外部情况之间互为依存、相互影响和制约的关系。

系统论要求:把事物或者现象当作系统来研究,并用数学模型去形貌和确定系统的结构和行为。系统的思索,区别于系统化的思索,系统的思索是要求我们把事情当做一各个个的系统来看。

系统的团体不是系统的部门之和,系统的团体肯定大于系统的部门之和。一个系统能支持的能力逾越于系统组成之和。比方汽车由轮子、发动机、车架组成。汽车都能行驶,但是轮子、发动机、车架都不能行驶。

   1.2 系统三大基本特性

目的性:任何系统都有肯定的目的。
这里可以理解为业务系统的边界。我们的系统是为了做什么事而设立的?能做什么事?不能做什么事?

动态性:动态性说明系统会发展。
放到我们的业务系统上来说,就是会演进,会向前动态发展。系统内部会随着时间而变革,系统与外部的交互关系也会随着时间而改变。

有序性:任何系统本质上都是有序的,如果不是,说明我们对系统的形貌还不够深刻。
如果我们的业务系统仍旧很乱,很杂,那说明我们还没有找到系统的深条理的结构,复杂是由于我们掌握不够。

   1.3 系统思维的四层境界

认识系统:认识并了解系统的形式与功能、结构与关系。

预测系统:当系统发生某个事件时,能够根据已有知识对系统的行为做出预测。

决策系统:对系统充足了解,拥有充足的依据,可以干预系统,对系统进行认定、分析、权衡,最终做出决策。

组装系统:系统思维的最高境界,可以根据系统的部件重组一套系统。

系统思维的方法论:
通过抽象思维识别出系统中的实体并用概念模型表达。

通过团体思维对关键题目进行分析、归纳,筛选出得当的实体作为系统的组装部件。

   1.4 系统的分类

系统的分类有很多,按照不同的维度可以分别不同的系统,比方按照是否人工可以分为人工系统、天然系统、社会系统等。

这里简要讲一下两个系统,决定论系统,演化系统。

决定论系统:有明确的因果关系,掌握系统内部规律就可以做出明确的判断。机械系统、软件系统等均属于这个范畴。

比方飞机、汽车等只要掌握对应的物理原理,就能够让飞机飞行,让汽车在马路上奔驰。

演化系统:更多的是相关性,因果关系不明确或者难以理清,其难度是深不可测。比方人类的免疫系统,医学上固然知道免疫系统,但是仍旧难以理清其原理。人类的大脑,天然界中的蚁群系统,天然界的生态均衡系统等。

对于不同的系统,有不同的方法论,处置惩罚的战略也不一样。

系统论是一门科学,也是一门哲学,有兴趣可以深入研究,这里只是蜻蜓点水。



02



关于架构的理解

“把桌子放在房间里看,把房间放在院子里看,把院子放在城市规划里看。”

   2.1 什么是架构

架构,是对系统的形貌。

维基百科的定义是:软件架构是有关软件团体结构与组件的抽象形貌,用于引导大型软件系统各个方面的计划。

系统的三大特性体现在架构上就是:横向可并列,纵向可推导,团体可演进。

物理学的熵增定律表明孤立系统总是趋向于熵增的方向发展。在软件系统里同样适用,只不过是以复杂度的增加体现的。

互联网软件系统总是朝着复杂度增加的方向发展。以是架构的第一目的是控制复杂,使系统朝着可控的方向发展。

   2.2 什么是好的架构图

简洁抽象:好的架构图肯定是简洁的,体现上简洁有力,能够一眼看上去就经纬分明。有肯定的抽象度的,如果一个架构图存在各种飞线环线,那肯定是抽象的不够。抽象才故意义,架构里如果存在各种细节,那就是堆砌。

可解释:好的架构图肯定能够用来解释当前系统的现状和行为。

引导行动:好的架构图肯定是可以引导行为的,引导行动才是架构图的最大代价。能够预测将来,引导行动。对于某个领域架构图,根据架构图都不知道把某个模块放哪里,那就是失败的。好的架构图应该是对于一个没有履历的人,都能根据架构来做模块分别。

可进化:对应于系统的动态性,架构也会随着时间而进化的。不能进化的架构就像花瓶,看着很美,一碰就碎。

   2.3 架构图

对架构的呈现业界已经存在不同的框架。有4+1视图、C4 模型、TOGAF 提出的企业架构模型等。不管哪种模型,其核心思想都是从不同的维度对软件架构进行形貌。下面着重从这几个方面来简述。

   2.3.1 4+1模式

4+1视图由 Philippe Kruchten 提出的对软件工程逻辑架构的形貌,现在已经成为事实上的软件结构尺度,分别以终端使用者、开发者、系统工程师、软件经理等不同的视角对软件进行形貌。如下图所示:




逻辑视图(Logic View):终端使用者的视角,从功能角度来形貌不同功能组件的条理关系。

开发视图(Development View):开发者视角下,从实现层面形貌不同代码的包、类、库的构成关系。

过程视图(Process View):不同组件之间的行为关系,通常以时序图的形式来体现,有肯定的时序延展性。

物理视图(Physical View):部署视图,系统所依托的物理视图。

场景视图(Scenarios):系统所涉及的不同对象之间的关系。通常以用例图的形式来呈现。

基于这5个视角,可以衍生出5种架构模型。场景、功能、实现、过程、部署,一层层的抽象。

4+1架构视图,构建了一个观察了解系统框架。它告诉我们可以从逻辑视图、开发视图、过程视图、物理视图、场景视图这几个层面来对系统进行形貌、观察、理解。对于一个系统,这5个视角已经是很完备了。值得注意的是4+1更大的代价是提供了一套分析系统的框架,实际上怎么呈现不同的团队可能有不同的形式。对于一个系统从不同的视角看会得到不同的理解,横当作岭侧成峰。

   2.3.2 C4模型




C4 模型是由 Simon Brown 在2006年至2011年之间创建,在4+1模型的基础上创建( https://c4model.com/ ),实际上就是以下4个单词的缩写:

上下文 Context:形貌的系统与周边系统、人的关系。重点是该系统与外界的关系。这里的外界包含人、以及其他的系统。 

容器 Containers:容器是一个功能的单位,是从技术层面来形貌,可以是一个服务,也可以是一个技术组件或者一个功能模块。比方一个基金系统会包含交易服务、订单服务、商品服务等。

组件 Components:组件是容器的的组成,组件是对容器的放大,比方商品服务里包含 sku 管理、行情数据、衍生指标等。

代码 Code:这一条理是代码级别,包含接口、类、对象的继承、组合、包含等。

该模型是对一个系统从宏观到微观逐级展开来形貌,如同拿着放大镜从太空看地球一样。

第一层看到的是地球与其星球的围绕、第二层是看到地球上的山川海河,第三层看到的是不同的国家城市,第四层看到的是不同的房子家庭。

C4 模型基于4+1模型,但是也有些差异。如果说4+1重点是横当作岭侧成峰。那 C4 模型则是一窥到底的放大镜。

C4 模型告诉我们,不同抽象条理的关注点、挑战点、题目域都是不同的,站在不同的条理就要思索对应的事情。

关注点一旦与该条理不匹配就会出现逻辑庞杂题目。能分清楚题目域在何种条理其实已经把题目解决一泰半了。

偶然间,在低条理很难懂的题目,上升一个条理就迎刃而解了。 

偶然间,在高条理看不清的题目, 低沉一个条理就一目了然了。

高条理是低一层的抽象,低条理是高一层的具化。

高手应该是能够识别不同的抽象条理,并且可以游刃有余地在不同抽象条理之间穿梭。

处于高条理时不应该被低条理的详细牵绊,处于低条理的时间也不应该好高骛远。

   2.3.3 TOGAF-4A 架构




业务架构:业务战略,治理,组织和关键业务流程。从企业视角来看,重在代价、信息、协作,关联多部门。

应用架构:要部署的各个应用程序的蓝图,其交互以及与组织核心业务流程的关系。

数据架构:一个组织的逻辑和物理数据资产和数据管理资源的结构。

技术架构:支持部署业务,数据和应用程序服务所需的逻辑软件和硬件功能。这包括IT基础设施,中间件,网络,通讯,处置惩罚和尺度。

TOGAF 认为架构的目的是为了资助企业实现如下能力:
异构到同构(塑造同构 IT)、过后到事先(塑造规划 IT)、离散到统一(塑造统一 IT)、无序到有序(塑造有序 IT)

   2.3.4 实际模型-互联网模型

实际上,相对于传统的软件系统,互联网行业发展比较快,业务存活周期比较短,就形成了互联网行业特定的架构形貌方式。更多是以业务架构、技术架构、部署架构三种形式呈现。

业务架构:从业务角度形貌系统承载的功能集合、领域边界、各组成部门的逻辑关系。区别于技术架构,业务架构图里制止出现技术类的术语,如 DB、MySQL、CMQ、同步、异步、并发等。 

技术架构:从技术角度形貌系统各组成部件之间的交互关系,技术架构体现的要具有技术特色,比方同步、异步、消息等。

部署架构:从物理角度形貌系统的部署分布。

   2.4 微服务的理解

软件架构归根结底无非两种模式:从技术层面和业务功能层面来计划。在理解这两个之前先区分一下技术语言和业务语言:

技术语言:是实现层面的。如 DB、MySQL、查询、超时、读写分离、快慢分离、逻辑层、缓存、创建订单、同步、异步、多线程、多历程。

业务语言:是功能层面的。如买入、取出、基金信息、行情、基金详情、资产、产品列表、持仓列表、申购列表、赎回列表。

技术人员要做的是摆脱技术语言体系,走进业务体系,不能被技术语言限制住。从本质上来说技术是为了业务服务的,以是理解业务第一,技术第二。对业务有了深刻的理解,再转过去用技术来实现业务。最好的实践就是在业务代码中看不到技术词汇,只有业务。

微服务最早由martinfowler提出,定义如下:
“In short, the microservice architectural style  is an approach to developing a single application as a suite of small services, each running in its own process and communicating with lightweight mechanisms, often an HTTP resource API. These services are built around business capabilities and independently deployable by fully automated deployment machinery. There is a bare minimum of centralized management of these services, which may be written in different programming languages and use different data storage technologies.” --- https://www.martinfowler.com/architecture/

说一下我的理解,微服务不是小服务,如果只是由于规模小,那直接叫小服务即可,更正确的叫法是:小而完整的服务,这里的小是指体积,完整是指能够提供完整的业务能力。微服务是一种理念,其表达的是用一个服务来表达一个实体相关的全部行为,某个实体与外部的全部接洽均通过该服务来发生。区别于以往按照技术功能分别的服务,ao 做逻辑层,dao 做存储层,vo 做展示层。一个实体的行为要通过 vo、ao、dao 三个服务的关联才能表达出来。而微服务是纯粹从业务语义层面出发,只必要一个服务,对外的体现只有一个。类似于一个国家,固然小,但是有自己的法律、武装、税收等。微服务拥有自己的逻辑、存储、领域等。微服务核心思想:服务即实体,我即全部。服务是实体概念的载体。其出发点是从业务领域或者功能层面就进行彻底的解耦。微服务之间完全异构,微服务之间甚至都无技术层面的共通性。

比方代表保单的微服务,全部跟保单的相关行为都是该服务提供的,该服务内部实现保单的存储和查询,外界无需关心,创建保单、查询保单、理赔保单均是通过该保单微服务实现的。

但是在实操中,限于硬件水平和当前的技术能力,单个微服务又难以承接实体相关的全部行为。比方保单的查询对性能要求比较高,保单的写入对一致性要求比较高,这种情况下,如果放在一个服务里就会带来实现上的困难。这时可能又会回到了传统技术功能分别服务上来,思量读写分离,分出一个查询和读的保单微服务。偶然间也是无奈的妥协,但是一样平常的原则是先坚持原则再妥协。先按照微服务领域的不可分割性来计划,遇到技术性的挑战再做调整与妥协。



03



关于复杂的理解

“计算机编程的本质就是控制复杂度”   ---Brian Kernighan

   3.1 什么是复杂?

对于一个系统来说达到怎么样的情况下才是复杂呢?物理学家劳埃德提出了一个观点:
形貌它有多困难;
产生它有多困难;
其组织程度怎样?

我个人的理解是,如果对于一个系统出现如下情况,即可认为是复杂的:
无法表达其概念,超出了人类语言的表达能力范畴
无法形貌其过程,超出了人类的理解能力。
无法度量其结果,没有度量就无法管理,复杂到难以有精确的方式进行度量。

   3.2 复杂的分类



  • 外貌复杂度:一个系统经过抽象、简化、分层、构建呈现出来的复杂度,是人类最直观理解的复杂度。比方一个系统架构图所呈现的复杂度就是外貌复杂度。
  • 必备复杂度:支持一个功能所必要的必备复杂度,也就是理论复杂度。
  • 实际复杂度:实际上包含由于技术限制、资源限制、过程浪费导致的不必要的复杂度。

外貌复杂度是人类所能理解的复杂度,必备复杂度和实际复杂度往往超出人类的理解能力。

有一种观点认为:系统架构的目的就是为了把系统的外貌复杂度控制在人类的理解范畴内,把实际复杂度低沉到接近必备复杂度。

   3.3 CyneFin 框架

关于复杂,内涵很丰富。有一个大佬叫戴夫·斯诺登,他于1999年创建了一套辅助决策的框架 Cynefin 框架,这套框架里就很好地把我们平常说的复杂进行了归类。见下图。




这个图直观上看,分五个象限,从右下角依次逆时针看。

Simle(简单)、Complicated(繁杂)、Complex(复杂)、Chaotic(杂乱),中间有一个黑色区域是Disorder(无序)。

这五组概念,可以理解为复杂度逐级提高。简单理解:


  • Simple(简单):知道因就能知道果。
  • Complicated(繁杂):由因可能推出不同的果,必要肯定的领域知识,才能分析出因果。
  • Complex(复杂):不知因,也不知果。直观上找不出因果,必须过后复盘才可以。
  • Chaotic(杂乱):知道因果不紧张了,紧张的是要构建秩序,使系统稳固下来。
  • Disorder(无序):复杂到都无法按照以上四个概念定义。

我们平常遇到的任何的业务、情况、情况、项目、系统都可以用这五个概念中的一个来形容。

一个系统的发展也大概会沿着从简单->繁杂->复杂->杂乱->无序的状态发展。这个过程跟物理中的熵增概念很符合。

Simle(简单):已知的知识,存在直接因果关系,一看就明白。这个不需多说,任何我们已经认识的系统,都是如许的。

对于这种状态的,我们最好应对方式,是采用感知-分类-响应模式。因果关系非常明确,我们只必要进行归类就好。

Complicated(繁杂): 这个系统存在大量的已知的未知,非专业人士很难看出其中的因果关系,必要专业人士联合大量的专业知识才能分析出因果。

比方在政府部门的设置上分纵线和横线两套体系,俗称“条条块块”。既垂直又水平。某县教导局纵线要向上级教导厅汇报,横线又要向地方县政府汇报。诸多类似的部门形成了错综复杂的关系,呈现出来就是网状的关系。面临如许的系统,体制外的人很难理清某个部门应该向谁汇报。这个时间如果来个公务员老司机,他能够很快速地告诉你其中的奥秘。

再比方,对于一个没有任何医学专业背景的人,你给他一堆指标,然后问他为啥会胃痛。他肯定以为太繁杂了,无从下手。对于他来说最好的方式,就是讨教医学生或者系统性学习医学类的专业知识。

以是面临繁杂的情况,最好的方式是,学习领域知识,快速入门。实践上采用:“感知-分析-响应”的模式。注意重点是分析。分析的条件要拥有领域知识。以是深入学习+分析才是应对之道。大部门情况下我们遇到的是这种系统,我们必要的是增加专业技能,补充领域知识,提高识别能力。这种也最好解。

Complex(复杂):代表了未知的未知。存在不确定的情况,可能存在也可能不存在,必要复盘才能找到原因。必要逐步探索,通过反馈才能分析到原因。

比方你突然被提拔为一个管理者,你的任务是团队文化创建。面临这项任务,既不知道因也不知道果。由于团队文化是个很虚的东西,你都不知道怎么权衡。更不消说采取什么方法去预测了。对于这种,你只能通过试探,然后过后归因。

以是采用模式是:“探索-感知-响应”。关键是要去探索,不断地探索,不断地反馈,最终找到因果关系。

Chaotic(杂乱):杂乱状态通常是指危机时刻。是指你能接触到信息都是不稳固的。这种情况下因果关系不清晰,处于杂乱无序的状态。尝试去识别因果已经没故意义了。

处于各种不稳固中,行动起来,把无序状态稳固下来。用行动来构建秩序。

对于这种情况,统统未知,只要行动起来,通过行动构建秩序。使杂乱局面扭转到复杂的局面。这种状态下的应对模式是:“行动-感知-响应”。

Disorder(无序):复杂到无法对系统复杂度进行分类。完全无序,抓瞎状态。这种的应对战略,就是先观察,以静待变,等你理清楚了处于某种复杂度状态的时间,再去想对策。想不清复杂度,就不要动。一直想。直到你能区分系统处于以上四种状态的一种。

总结:

不同级别的复杂对应的处置惩罚战略也不一样。我们每天面临各种的情况,使用这个框架的引导思绪,有助于我们透过现象看本质。能力越强的人处置惩罚的复杂度的也越高。



04



跋文

本文的内容是联合以往的学习、收集整理而来。越整理越发现里面的知识越庞大,每个点都可以展开。以是这里很多地方只是简要带过,偶然间再进一步整理。推荐三本书 :

《系统架构-复杂系统的产品计划与开发》对我来说,简直是开天眼的书。本文的有些思绪和语句也是从这本书里摘录的。

《软件架构-架构模式、特性及实践》

《领域驱动计划》 这本书在笔者部门几乎人手一本。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

篮之新喜

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表