.NET 云原生架构师训练营(系统架构)--学习笔记

 点击上方“DotNet NB”关注公众号

回复“1”获取开发者路线图

1c2a426eb0fb4a013099be159823f84e.gif

学习分享 丨作者 / 郑 子 铭    

这是DotNet NB 公众号的第176篇原创文章

目录

  • 对外展现的功能

  • 内部功能

  • 功能交互与价值通路

  • 系统架构

目标

  • 认识系统的价值通路

  • 认识功能架构,通过把功能结构与形式结构结合来描述系统架构

受益原则

好的架构必须使人受益,要想把架构做好,就要专注于功能的涌现,使得系统把它的主要功能通过跨越系统边界的接口对外展示出来

对外展现的功能

ASP .NET Core 的使用者是程序员,最终的受益是老板

c4596321dab1723334b8f4081e7f8e28.png

上一讲对 ASP .NET Core 的描述是文字性描述,是一种非结构性描述,不是很准确,因为每个人对文字的理解都不一样

ASP .NET Core 对外展现的功能和价值可以主要拆分为两个过程:启动和执行

启动的时候有目标,就是代码;执行的时候有请求和响应

如何描述一个功能

28888a29211d5aed23cb01b8050d4d0f.png

一个过程通常会改变操作数对象的状态(包括创建、销毁)

7a50d822c66bc30bbdf10d4235b70431.png

功能需要由一个形式来进行承载,有时候我们也称之为工具对象(你的代码)

比如烧水需要一个烧水壶,但是烧水壶没办法提供热水,这个系统通过把水加热给我提供热水

加热是过程,水是操作数对象,通过加热的过程改变了水的温度,实现了整个系统的目标,为我提供热水

这里面我们可以发现加热需要一个工具对象,使用什么进行加热,燃气灶、柴火还是煤气

功能就是通过一个工具对象实施一个过程来改造一个目标操作数对象的一些状态来实现一些目标

ASP .NET Core 对外展现的功能和价值

与价值有关的操作数与价值有关的属性及状态与价值有关的过程系统的形式
web 请求web 请求响应体影响/改变带自托管的 WEB FRAMEWORK
  • 系统所带来的利益与它对外展现的功能有关

  • 系统中的过程,会对与价值有关的操作数进行操控,并以此产生利益

内部功能

专注于系统对外展现的主要功能,也就是会对与价值有关的操作数进行创建、销毁、或影响的那个过程

主要内部操作数主要内部过程
tcp 网络请求接收
c# 可识别的请求写入 Response
tcp 网络格式化

如何找到内部过程

首先找到对外展现的功能,对外展现的功能里面必然包含一个操作数对象,这个操作数对象在内部必然会经过若干个过程的影响,最后实现了整体的功能

所以和最有价值的操作数对象相关的内部过程就可以提炼出来,形成一连串的动作,然后形成价值通路

比如电商系统中,核心的功能是完成用户购物,与价值有关的操作数是订单对象

从外部展现来看是用户创建订单,订单发货

从内部来看就会围绕订单对象,创建订单,确认订单,订单打通,订单发货,订单签收

功能交互与价值通路

功能架构:过程之间共享、或交互的操作数 = 功能交互功能与功能交互,合起来构成功能架构

价值通路:功能架构中包含价值通路,使得价值通路可以沉着这条通路而传递。利益就是沿着这条通路向下进行的,并最终演化为价值

72cd6fcaf98dbcb88a11bd08ee025151.png

不在价值通路上的东西

  • 形式实体,形式是某个功能的工具,不在功能架构之内

  • 对外展现的次要功能、提供支持的过程和操作数

  • 对良好的外部功能起不到涌现作用的过程及操作数

  • 对系统起到支撑作用的其它过程和形式

次要外部功能及内部功能

必须展现出与价值有关的主要功能,以体现该系统存在的意义,除此之外,它还可能展现出一些与价值有关的次要功能

8c25533cbe20c8884ab43bad7cd4e49f.png

系统架构

f5a4e879ff767fa5831ee0be58d8d040.png

这是一个形式结构,SERVER 是形式实体

85bda9680461eb333f05490e18a774b0.png

这是功能架构,接收是一个过程,C#可识别的请求信息是一个操作数对象

架构是形式结构和功能架构的结合

b3a1bb73315d1ae8e41644d678ab4f22.png

这是一个动静结合的系统架构,既会告诉你系统对外的一些功能和价值是如何实现的,同时也会告诉你它有哪些内部的实体来满足的

总结

  • 系统架构由功能架构与形式元素及形式架构相结合而成

  • 系统架构是通过系统结构和行为的组合使系统提供功能

  • 功能就是系统的顶层过程,系统架构(结构-行为组合)用于支持系统执行其顶层过程,进而使系统实现其功能为客户创造价值

架构模式

模式:描述的是一种关系(类与类的关系、组件与组件的关系),并且这种关系是可复用的!

特定上下文:说明这种关系的适用场景是有限制的,只能在特定场景下能适用!

常见问题:说明这种关系是解决某个问题或某类问题的解决方案。

  • Layered pattern

  • Client-server pattern

  • Master-slave pattern

  • Pipe-filter pattern

  • Broker pattern

  • Peer-to-peer pattern

  • Event-bus pattern

  • Model-view-controller pattern

  • Blackboard pattern

  • Interpreter pattern

作业

在 1.1 的作业中,你将你认识的那个系统进行了形式上的分解。

请进一步思考,该系统对外提供的功能是通过什么样的价值通路实现的?

请画出该系统的价值通路(通过功能架构图来体现价值通路)。

把功能架架构 与1.1中的形式相结合,形成架构图,请画出该系统的架构图。

课程链接

https://appsqsyiqlk5791.h5.xiaoeknow.com/v1/course/video/v_5f39bdb8e4b01187873136cf?type=2

推荐阅读:

《Kubernetes全栈架构师(Kubeadm高可用安装k8s集群)--学习笔记》

《.NET 云原生架构师训练营(模块一 架构师与云原生)--学习笔记》

《.NET Core开发实战(第1课:课程介绍)--学习笔记》

点击下方卡片关注DotNet NB

一起交流学习

cf3594321eb614badb5f69c2cf6dcad6.png

▲ 点击上方卡片关注DotNet NB,一起交流学习

请在公众号后台

回复 【路线图】获取.NET 2021开发者路线图

回复 【原创内容】获取公众号原创内容

回复 【峰会视频】获取.NET Conf开发者大会视频

回复 【个人简介】获取作者个人简介

回复 【年终总结】获取作者年终总结

回复 加群加入DotNet NB 交流学习群

长按识别下方二维码,或点击阅读原文。和我一起,交流学习,分享心得。

996ecfe4b21ed93f8d632d862c9908c4.gif

a911e493458c9efdb930c93abf5e63a9.png

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

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

相关文章

JFinal整合CKFinder

2019独角兽企业重金招聘Python工程师标准>>> 使用JFinal对之前的系统进行重构,老系统使用了CKEditorCKFinder编辑器,发现在web.xml中配置ConnectorServlet会被JFinalFilter过滤处理,而且使用JFinal之后也不想在web.xml中增加额外的…

.NET 6新特性试用 | TryGetNonEnumeratedCount

前言.NET 6新增了TryGetNonEnumeratedCount方法&#xff0c;计算可枚举类型的元素总数。LINQ不是已经有了Count方法吗&#xff0c;为什么还要画蛇添足呢&#xff1f;Demo尝试下列代码&#xff1a;var b new B<int>(); Console.WriteLine($"{b.Count()}");var …

研究表明:喝酒“上脸”是基因突变,不仅容易老年痴呆,还容易得胃癌

全世界只有3.14 % 的人关注了爆炸吧知识本文转自科研大匠“喝酒上脸的人能喝&#xff01;”这句话&#xff0c;不管来自天南还是海北的&#xff0c;在酒桌上&#xff0c;肯定都耳熟能详有没有&#xff1f;其实&#xff0c;喝酒“上脸”并不意味着能喝&#xff0c;而是一种基因突…

本科、硕士、博士的区别(终极版)

全世界只有3.14 % 的人关注了爆炸吧知识本文转自募格学术本科生和研究生到底有何区别&#xff1f;硕士和博士又有什么不同&#xff1f;这是很多人都有的困惑&#xff0c;对于这个问题的说法也有很多版本&#xff0c;我们挑选了几个比较经典的版本&#xff0c;以期能和大家一同探…

Linux 环境变量 $PATH

我们知道查阅文件属性的指令 ls 完整文件名为&#xff1a;/bin/ls(这是绝对路径)&#xff0c;那为什么可以在任何地方执行/bin/ls 这个指令呢&#xff1f; 为什么在任何目录下输入 ls 就一定可以显示出一些讯息而不会说找不到该 /bin/ls 指令呢&#xff1f; 这是因为环境变量 …

文件项目SVN+TortoiseSVN+Subclipse使用总结

近来使用开辟的过程中涌现了一个小问题&#xff0c;顺便记录一下原因和方法--文件项目 一、SVN、TortoiseSVN、Subclipse分析 团队开辟技术&#xff1a; (1)单元测试&#xff1b;(2)版本控制&#xff1b; (3)项目主动化&#xff1b; SCM:软件配置管理&#xff0c;包含SVN&#…

PHP中常见的五种设计模式

设计模式只是为 Java架构师准备的 — 至少您可能一直这样认为。实际上&#xff0c;设计模式对于每个人都非常有用。如果这些工具不是 “架构太空人” 的专利&#xff0c;那么它们又是什么&#xff1f;为什么说它们在 PHP 应用程序中非常有用&#xff1f;本文解释了这些问题。 设…

Java常用类集接口以及实现方式总结

最近学习map-reduce原理以及map-reduce编程&#xff0c;于是顺带着学习下Java编程&#xff0c;对于Java常用的数据结构和类集&#xff0c;我总结到mind图中&#xff0c;便于理清相互之间的关系 package leiji; import java.util.ArrayList; import java.util.List; import java…

Android之Launcher分析和修改1——Launcher默认界面配置(default_workspace)

www.cnblogs.com/mythou/p/3153880.html 最近工作都在修改Launcher&#xff0c;所以打算把分析源码和修改源码的过程记录下来&#xff0c;最近会写一些关于Launcher的分析和修改博文。因为我是修改4.0.3的Launcher&#xff0c;所以后面文章里面的Launcher都是基于Android4.0.…

如果你喜欢上了一个程序员小伙 献给所有程序员女友(来自ITeye博客的文章 作者:talent2012)...

程序员向来是善于幽默自嘲的群体&#xff0c;但从某种程度上影响了咱程序员在广大女同胞心中的印象啊&#xff5e;&#xff5e; 于是写下此篇&#xff08;有从别处看到的3句加进来的&#xff09;&#xff0c; 就算是为咱程序员做个广告&#xff5e;&#xff5e;要是觉得有点过的…

豆瓣9.6分!这部BBC的纪录片太让人震撼!

全世界只有3.14 % 的人关注了爆炸吧知识英国广播公司BBC的纪录片素来就是高质量的代名词&#xff0c;推出的《地球无限》(Planet Earth)、《地球的力量》(Earth The Power of the Planet)、《冷血生命》(Life In Cold Blood)等片不仅在英国播放时获得极高收视&#xff0c;还获得…

vim-snipmate编写snippet的语法

vim-snipmate真的很好用&#xff0c;以前好多编写代码的问题得到完美的解决。还附带提升我对vim的理解和信心&#xff0c;在这里感谢一下作者。thank you。 1、现说一下我浓缩的重要语法。 1、定义是下面这样&#xff0c;注意中间必须是一个制表符<TAB>不能用空格代替。 …

Android之Launcher分析和修改2——Icon修改、界面布局调整、壁纸设置

上一篇文章说了如何修改Android自带Launcher2的默认界面设置&#xff08;http://www.cnblogs.com/mythou/p/3153880.html&#xff09;。 今天主要是说说Launcher里面图标、布局、壁纸等的设置问题。毕竟我们一般修改Launcher&#xff0c;这些都是需要修改的地方&#xff0c;也是…

N 年沉淀,腾讯这套系统终于开源!

大家好&#xff0c;我是鱼皮&#xff0c;前段时间给大家介绍了字节跳动开源的两套设计系统&#xff0c;分别是 Arco Design 和抖音 Semi Design。而就在几天前&#xff0c;腾讯终于也开源了自家的设计系统 TDesgin &#xff01;这次&#xff0c;终于能介绍自己公司的项目了。如…

Android之Launcher分析和修改3——Launcher启动和初始化

前面两篇文章都是写有关Launcher配置文件的修改&#xff0c;代码方面涉及不多&#xff0c;今天开始进入Launcher代码分析。 我们开机启动Launcher&#xff0c;Launcher是由Activity Manager启动的&#xff0c;而Activity Manager是由system server启动。 原创博文&#xff0c…

史上最强物理科普!

全世界只有3.14 % 的人关注了爆炸吧知识一沙见世界 一花窥天堂手心握无限 须臾纳永恒杨振宁曾说读上面的四句诗可以感受到物理的美但物理的美不止于此物理还有一种庄严美一种神秘美一种初窥宇宙奥秘的畏惧美物理就是如此的迷人任何语言在它的面前都很贫瘠数学让人摆脱了愚昧而…

mysql 怎么实现随机查询并分页,不重复查询

2019独角兽企业重金招聘Python工程师标准>>> 需求&#xff1a; 企业应用中&#xff0c;一般数据量不是很特别多&#xff0c;同时大多在局域网内&#xff0c;性能不会有问题&#xff0c;一般不会分页处理&#xff0c;随机排序数据一般不会有问题 web网站中&#xf…

主机远程唤醒配置

配置&#xff1a;win10戴尔主机F2进biosbios设置2.系统设置3.以太网设置4.电源管理设置以上设置完成后关机&#xff0c;就可以在远程电脑上打开WakeMeOnLan&#xff0c;然后添加或者搜索需要唤醒的电脑的ip&#xff0c;mac和主机名称&#xff0c;然后就可以唤醒远程主机了查看m…

unix高级编程apue.h问题

2019独角兽企业重金招聘Python工程师标准>>> apue.h头文件为作者自己编写而非系统自带&#xff0c;故需要自行添加&#xff01;第一&#xff1a;打开网站 http://www.apuebook.com/第二&#xff1a;选择合适的版本&#xff08;一共有三个版本&#xff0c;根据书的版…