扩大
缩小
  

架构设计--建立系统观

一、目标

  • 通过整体定义去认识系统
  • 通过分解去简化对系统的认识

下面以ASP .NET Core为例

二、ASP .NET Core 是什么

WEB FRAMEWORK(形式)

三、ASP .NET Core 是干什么的

帮助我们快速地构建跨平台的、现代化的、高性能的、面向云的WEB应用程序(功能)

形式 + 功能 = 系统

你身边看到的那些系统:

形式功能
锤子 钉钉子
集装箱 存储货物
飞机 快速传输人或物

结论1:系统具有形式和功能的属性

四、Host、Server、HostApplication 与 ASP .NET Core 是什么关系

它们是构成 ASP .NET Core 的一部分

形式功能
Host 管理资源
Server 监听和处理网络
HostApplication 封装 HTTP 处理程序

结论2:系统由若干个(实体/部件/模块)组成,每个子实体也同时具有形式和功能属性,能够独立成为一个系统

一个集装箱可以被拆解成多个部分,每一个部分都有它的功能和属性

ASP .NET Core + Your code = 一个新系统

 

原则1:系统的涌现原则

系统的整体功能大于各部件之和

-预期的非预期的
良好的涌现 能处理HTTP请求 很适合云原生的场景
不良的涌现 会受到攻击,并发高的时候会瘫痪 程序员写的异常

非预期的良好的涌现:设计的时候没想到还能这样使用

五、ASP .NET Core 和 .NET Core 是什么关系

ASP .NET Core 是 .NET Core 的一部分,负责 WEB 这一类应用程序的处理

原则2:整体原则

每个系统都作为某一个或某些个大系统的一小部分而运作,同时,每个系统中也包含一些更小的系统。

例如在设计一个椅子的时候,可以把椅子放到一个房间里面去考虑,把房间放到整个建筑里面去考虑,把建筑放到整个社区里面去考虑,社区放到整个城市规划里面去考虑。

例如当我做 WEB FRAMEWORK 的时候只需要考虑 ASP .NET Core,但是当我需要做一个开发平台,比如 .NET Core 的时候,就不止是 ASP .NET Core 了,它只是这个平台上面开发 WEB 应用的东西。

除了 WEB 应用,开发平台还需要处理控制台应用 Console,移动端应用 Mobile,这个时候就会考虑有哪些组件除了给 ASP .NET Core 使用,同时还会给平层的或者更高层的使用。

这个时候就会抽象出 DI,Configuration,Logging 的这些部分,它们是 ASP .NET Core 的组成部分之一,但是同时它们也可以被 .NET Core 这个更大的系统里面的其他子系统使用。

当我们以整体的原则去思考的时候,可以满足更大的系统的需要,但同时成本也会更低,设计质量也会更好,不然可能会每个子系统都设计一个 DI,Configuration,Logging,如果一开始就以一个整体去考虑,就不会这样。

当我们需要为一个大系统添加一个小系统的时候,需要考虑整体可能会带来的影响,比如商城增加一个发放优惠券的功能,需要考虑优惠券对原来会员等级的优惠,平台的优惠有没有冲突,另外需要考虑优惠券对订单系统,库存系统,会员系统会不会有影响。

 

总结:

所有的系统都是由实体组成,实体本身也是一个系统。

所有的系统都可以作为一个实体,来构成一个更大的系统。

posted @ 2022-02-11 15:46  风筝遇上风  阅读(56)  评论(0编辑  收藏  举报