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

简介: 1.1 什么是软件架构1.2 软件架构的基本思路1.3 单体向分布式演进、云原生、技术中台

目录

  • 什么是软件架构
  • 软件架构的基本思路
  • 单体向分布式演进、云原生、技术中台

1.1 什么是软件架构

1.1.1 什么是架构?

Software architecture = {Elements, Forms, Rationale/Constraints}

元素、形式/模式、基本原理和限制

为什么需要软件架构?

软件架构的终极目标是用最小的人力成本来满足构建和维护系统的需求

一个软件架构的优劣,可以用它满足用户需求的成本来衡量。如果该成本很低,并且在系统的整个生命周期内一直都维持这样的低成本,那么这个系统的设计就是优良的,如果该系统的每次发布都会提升下一次变更的成本,那么这个设计就是不好的,就这么简单。

--架构整洁之道

产品经理

  • 需求分析
  • 需求设计
  • 项目管理
  • 产品运营

1.1.2 什么是架构师?

系统的维度

负责整体系统的架构设计,主要是基础服务和各系统间的协调上,着眼全局不太注重某个应用本身架构,比如关注服务器负载,可靠性,伸缩,扩展,数据库切分,缓存应用等方法的基础架构设计

应用程序的维度

负责某个应用的技术架构,主要偏业务系统,关注理解业务,梳理模型,设计模式,接口,数据交互等方面

业务流程的维度

关注某一个行业、业务的领域分析,获取领域模型,最终获得系统的模型

也可以叫业务领域专家、行业专家、产品咨询师、资深顾问

降低成本

通过设计和实现优良的软件架构来持续降低软件的构建和维护成本

软件架构这项工作的实质就是规划如何将系统拆分成组件,并安排好组件之间的排列关系以及组件之间互相通信的方式

如何降低成本?

  • 低成本维护(容易被改动和理解)
  • 软件可复用
  • 轻松部署

设计原则会给我们答案

软件架构师的目标是创建一种系统形态,该形态会以策略为最基本的元素,并让细节与策略脱离关系,一个优秀的软件架构师应该致力于最大化可选项数量

职能

  1. 负责公司系统架构设计、研发工作
  2. 承担从业务向技术转换的桥梁作用
  3. 协作项目经理制定项目计划和控制项目进度
  4. 负责辅助并指导 SA 开展设计工作
  5. 负责组织技术研究和攻关工作
  6. 负责组织和管理公司内部的技术培训工作
  7. 负责组织及带领公司内部员工研究与项目相关的新技术
  8. 管理技术支撑团队并给项目、产品开发实施团队提供技术保障
  9. 理解系统的业务需求,制定系统的整体框架(包括:技术框架和业务框架)
  10. 对系统框架相关技术和业务进行培训,指导开发人员开发
  11. 解决系统开发、运行中出现的各种问题
  12. 对系统的重用、扩展、安全、性能、伸缩性、简洁等做系统级的把握

软件周期内,标准组织架构下的各个职位的分工

  • CEO
  • CTO/CIO
  • 产品总监/技术总监/架构师 Architect Director
  • 资深开发/Manager
  • 高级开发/Leader

1.1.3 软件架构分类

从架构师的工作内容上来划分可以分为三类:

  • 系统架构师
  • 应用架构师
  • 业务架构师

系统架构师/基础架构师

从系统的维度,负责整体系统的架构设计,主要是基础服务和各系统间协调上,着眼全局不太注重某个应用本身架构,比如关注服务器负载,可靠性,伸缩,扩展,数据库切分,缓存应用等方面的基础架构设计。

应用架构师

从应用程序的维度,负责某个应用的技术架构,主要偏业务系统,关注理解业务,梳理模型,设计模式,接口,数据交互等方面。

业务架构师

从业务流程的维度,关注某一个行业、业务的领域分析,获取领域模型,最终获得系统的模型。也可以叫业务领域专家、行业专家、产品咨询师、资深顾问。

基础架构、前端架构、后端架构是从职责上的分类。

.NET云原生架构师训练营讲什么,怎么讲,讲多久

https://mp.weixin.qq.com/s/JWOIScGrX0Hszz4uqdA6qw

1.1.4 架构风格

  • 分层架构
  • 微核架构/六边形架构/简洁架构
  • 事件驱动架构
  • 微服务架构
  • 云架构

软件架构入门

http://www.ruanyifeng.com/blog/2016/09/software-architecture.html

1.2 软件架构的基本思路

1.2.1 如何理解需求

软件需求(第3版)

https://book.douban.com/subject/26307910/

需求分类

005.jpg

1.2.2 非功能性需求

  • 观感需求
  • 易用性:性能/可用性
  • 可扩展性
  • 可维护性

1.2.3 4+1模型

  • 场景视图
  • 逻辑视图
  • 开发视图
  • 处理视图
  • 物理视图

1.2.4 场景视图

  • 用户可以开设一个训练营成为营长
  • 营长可以制定训练营学生的任务和计划,可以快速利用到其他训练营
  • 营长可以邀请其他用户加入训练营成为学员
  • 营长可以对学员进行分组
  • 营长可以添加指定学员成为助教并指定到分组
  • 学员可以接受邀请加入训练营成为学员
  • 学员加入训练营之后可以完成训练营内的任务
  • 学员可以对训练营内的指定问题进行提问
  • 学员可以查看自己的学员档案
  • 营长/助教可以回答学员提出的问题
  • 营长/助教可以对学员完成的任务进行考评打分

006.jpg

1.2.5 逻辑视图

面向对象分解

用来支持功能性需求、系统应该被拆分为哪些问题域、对象

007.jpg

1.2.6 开发视图

关注软件模块组织和开发环境上、从组件、模块、子系统的组织和分层

每一层为上层提供有限的良好定义的接口供调用

008.jpg

  • 团队结构
  • 开发流程
  • 测试计划
  • 项目协作工具
  • Road Map 发布计划

1.2.7 处理视图

关注进程、线程、对象等运行的概念,以及相关的并发、同步、通信等问题

从软件实现的角度去关注非功能性需求

单体

009.jpg

分布式

010.jpg

2.8 物理视图

从硬件角度去关注非功能属性

单体

011.jpg

分布式

012.jpg

1.3 单体向分布式演进、云原生、技术中台

1.3.1 单体的问题

  • 巨大的代码库
  • 过载的 IDE
  • 过载的 WEB 容器
  • 持续部署困难
  • 应用扩展困难
  • 难于进行规模化开发

模式: 单体架构

https://microservices.io/patterns/cn/monolithic.html

1.3.2 高可用架构

系统设计

  • 故障转移
  • 超时控制
  • 降级和限流

系统运维

  • 灰度发布
  • 故障演练

故障转移

完全对等的节点之间做故障转移

在对等节点之间做故障转移,相对来说简单些

在这类系统中所有节点都承担读写流量,并且节点中不保存状态,每个节点都可以作为另一个节点的镜像

不对等的节点之间,即系统中存在主节点也存在备节点

使用最广泛的故障检测机制是“心跳”

你可以在客户端上定期地向主节点发送心跳包,也可以从备份节点上定期发送心跳包

当一段时间内未收到心跳包,就可以认为主节点已经发生故障,可以触发选主操作

超时/降级/限流

数据库访问超时、rpc/远程调用超时、缓存/队列等其他中间件访问超时
探测出系统或者服务单位内允许出现的最大请求,直接拒绝后面的请求

水平/垂直扩展

水平(也叫横向扩展):用更多的节点支撑更大的请求

如成千上万的蚂蚁完成一项搬运工作

垂直(也叫纵向扩展):扩展一个点的能力支撑更大的请求

如利用一个人的能力,如蜘蛛侠逼停火车

AKF 扩展立方

X 轴:代表无差别的克隆服务和数据,工作可以很均匀的分散在不同的服务实例上

Y 轴:关注应用中职责的划分,比如数据类型,交易执行类型的划分

Z 轴:关注服务和数据的优先级划分,如分地域划分

业务模块化打造单体和分布式部署同步支持方案

https://mp.weixin.qq.com/s/HE7BxH_RZo45bY2baNgt5Q

模块拆分原则

  • 微服务拆分的大部份原则依旧适用
  • 一个业务模块对应一个数据库,不能直接查另一个业务模块的数据库
  • 模块之间的调用通过抽象契约接口来完成
  • 模块之间互相依赖只能依赖于抽象契约

1.3.3 云原生

什么是云原生

云原生技术有利于各组织再公有云、私有云和混合云等新型动态环境中,构建和运行可弹性扩展的应用

云原生的代表技术包括容器、微服务、服务网络、不可变基础设施和声明式 API

这些技术可以让我们构建高度稳定、可控、可观测的松散耦合应用

但云原生方案的重点并不是应用部署在何处,而是如何构建、部署和管理应用

014.jpg

关键点

12 因素

  1. 基准代码:基准代码和应用之间总是保持一一对应的关系:
  • 一旦有多个基准代码,就不能称为一个应用,而是一个分布式系统。分布式系统中的每一个组件都是一个应用,每一个应用可以分别使用 12因素 进行开发
  • 多个应用共享一份基准代码是有悖于 12因素 原则的。解决方案就是将共享的代码拆分为独立的类库,然后使用 依赖管理 策略去加载它们
  1. 显示声明依赖
  2. 配置:推荐将配置保存于环境变量中
  3. 把后端服务当作附加资源
  4. 严格分享构建和运行
  5. 以一个或多个无状态进程运行应用
  6. 通过端口绑定提供服务:12因素 应用完全自我加载,而不依赖于任何网络服务就可以创建一个面向网络的服务。互联网应用通过端口绑定来提供服务,并监听发送至该端口的请求
  7. 通过进程模型进行扩展
  8. 快速启动和优雅终止可最大化健壮性
  9. 尽可能的保持开发,预发布,线上环境相同
  10. 把日志当作事件流
  11. 后台管理任务当作一次性进程运行

云原生 VS 微服务

云原生方案与微服务架构类似

然而,尽管微服务可通过构建云原生应用来交付,可企业仍需要采取许多措施,才能在生产环境中熟练地管理微服务

而想要享受云原生应用的各种益处,也并非一定需要微服务

很多企业都通过基于相同的原则,构建出更优秀的模块化单体式应用,从而取得云原生方案的种种效益

1.3.4 技术中台

013.jpg

目录
相关文章
|
7月前
|
存储 架构师 测试技术
架构之道——人人都是架构师
本文的探讨和编写主要围绕三个方面:架构是什么?架构师要解决的问题有哪些?解决这些问题的方法论是什么?最后作者希望人人都能具备架构师思维。
|
10月前
|
机器学习/深度学习 人工智能 架构师
【架构师】AI时代架构师必备技能
【架构师】AI时代架构师必备技能
198 5
|
5月前
|
缓存 NoSQL Java
秒杀圣经:10Wqps秒杀,16大架构绝招,一文帮你秒变架构师 (2)
高并发下的秒杀系统设计是一个复杂的挑战,涉及多个关键技术点。40岁老架构师尼恩在其读者交流群中分享了16个关键架构要点,帮助解决高并发下的秒杀问题,如每秒上万次下单请求的处理、超卖问题的解决等。这些要点包括业务架构设计、流量控制、异步处理、缓存策略、限流熔断、分布式锁、消息队列、数据一致性、存储架构等多个方面。尼恩还提供了详细的实战案例和代码示例,帮助读者全面理解和掌握秒杀系统的架构设计。此外,他还分享了《尼恩Java面试宝典》等资源,帮助读者在面试中脱颖而出。如果你对高并发秒杀系统感兴趣,可以关注尼恩的技术自由圈,获取更多详细资料。
秒杀圣经:10Wqps秒杀,16大架构绝招,一文帮你秒变架构师 (2)
|
5月前
|
缓存 NoSQL Java
秒杀圣经:10Wqps高并发秒杀,16大架构杀招,帮你秒变架构师 (1)
高并发下,如何设计秒杀系统?这是一个高频面试题。40岁老架构师尼恩的读者交流群中,近期有小伙伴在面试Shopee时遇到了这个问题,未能很好地回答,导致面试失败。为此,尼恩进行了系统化、体系化的梳理,帮助大家提升“技术肌肉”,让面试官刮目相看。秒杀系统设计涉及16个架构要点,涵盖业务架构、流量架构、异步架构、分层架构、缓存架构、库存扣减、MQ异步处理、限流、熔断、降级、存储架构等多个方面。掌握这些要点,可以有效应对高并发场景下的秒杀系统设计挑战。
秒杀圣经:10Wqps高并发秒杀,16大架构杀招,帮你秒变架构师 (1)
|
6月前
|
编解码 Linux 开发工具
Linux平台x86_64|aarch64架构RTMP推送|轻量级RTSP服务模块集成说明
支持x64_64架构、aarch64架构(需要glibc-2.21及以上版本的Linux系统, 需要libX11.so.6, 需要GLib–2.0, 需安装 libstdc++.so.6.0.21、GLIBCXX_3.4.21、 CXXABI_1.3.9)。
162 0
|
8月前
|
存储 架构师 测试技术
架构之道:人人都是架构师(2)
每个业务系统的开发者都应该具备一定的架构师素养,架构师的重要职责不仅仅是做决策,更重要的是提升团队的整体能力。一个好的架构师应该聚焦于业务和系统,定义问题和结果,设计系统、模块和代码,同时也需要解决跨域问题,确定团队间的边界,制定规范,统一语言,并创建一个让每个人都能成长为架构师的环境,以促进团队的敏捷性。本文旨在探讨如何培养架构思维,并阐述了架构师的职责、能力模型、方法论,以及如何成为架构师。
224 10
|
8月前
|
存储 运维 架构师
架构之道:人人都是架构师(1)
架构之道:人人都是架构师
278 8
|
9月前
|
前端开发 JavaScript 架构师
Webpack模块联邦:微前端架构的新选择
Webpack的模块联邦是Webpack 5引入的革命性特性,革新了微前端架构。它允许独立的Web应用在运行时动态共享代码,无需传统打包过程。基本概念包括容器应用(负责加载协调)和远程应用(独立应用,可暴露模块)。实现步骤涉及容器和远程应用的`ModuleFederationPlugin`配置,以及在应用间导入和使用远程模块。模块联邦的优势在于独立开发、按需加载、版本管理和易于维护。通过实战案例展示了如何构建微前端应用,包括创建容器和远程应用,以及消费远程组件。高级用法涉及动态加载、路由集成、状态管理和错误处理。
153 3
|
9月前
|
监控 Java 关系型数据库
java版MES系统源码,后端采用 Spring Boot 多模块架构
MES系统采用Vue3的vue-element-plus-admin为后台,Spring Boot多模块架构,支持MySQL、Oracle等数据库,具备SaaS多租户功能。核心功能包括车间计划排程、工艺流程配置、生产质量管理、进度追踪、库存和排班管理等,全面覆盖生产运营关键环节。
139 0
java版MES系统源码,后端采用 Spring Boot 多模块架构
|
10月前
|
运维 架构师 安全
架构师养成手册:架构师职责
小米是一名热情的技术爱好者和架构师,他探讨了架构师的角色和职责。主要涉及六个方面:顶层设计,需与企业战略目标对齐,制定架构原则;规划可适应未来变化的企业架构,分析需求并关注技术趋势;全局视角制定可落地的架构方案,兼顾全局与局部优化;技术选型与难题解决,选择合适技术并解决实际问题;关注方案与代码的广度与深度,确保宏观设计与微观实现的统一;同时,架构师还需具备管理能力,包括团队协作、资源调配和风险管理。
251 11

热门文章

最新文章