本文主要内容来自 SpriCoder的博客,修改了一些翻译错误和笔误,修改了一些表格的样式,添加了 2022 年考题和解答。
软件架构简答题
软件架构介绍
- 【2015】【2019】软件架构来自哪里?列举五种可能的软件架构的来源 Where do software architecture come from? List five possible sources of software architecture.
- NFRs
- ASRs
- 质量需求
- 涉众,组织
- 技术环境
- 业务目标
- 商业与技术决策组合
- 【2017】【2019】【2022】在设计软件时应用了哪些通用设计策略?为每个策略提供一个带有软件架构的简明工作示例。What are generic design strategies applied in designing software? Give a concise working example with software architecture for each strategy.
- 分解:针对某一个系统关注点分解后处理,比如将整个系统分解或将某个模块分解。
- 抽象:使用抽象让设计师关注本身结构而不关心实现,比如将系统抽象为组件和连接件或抽象为模块。
- 逐步求精-分而治之:将每个模块分别处理
- 生成与测试:将一个特定的设计看作是一个假设;根据测试路径生成测试用例。
- 迭代-增量细化:使用迭代的方法,ADD 方法多次迭代直到满足所有 ASR
- 复用元素:重用在设计过程中出现了可以复用的元素,重用现有架构
- 【2019】Architecture,structure 和 Design 的区别?
- Design 包含 Architecture,Architecture 包含 Structure
- 体系结构是关于软件设计的,所有体系结构都是设计,但是不是所有的设计都是体系结构,体系结构是软件设计的一个部分
- 结构是静态的、逻辑的,是关于系统如何构成的
- 体系结构除包含架构,还会包含组件之间的相关的关系结构,并定义一些动态的行为。
- 【2015】【2017】简要描述软件架构过程中的一般活动,以及每个活动的主要输入和输出。Briefly describe the general activities in a software architecture process, and the major inputs and outputs at each activity.
- 【2017】【2019】描述 4+1 视图 Describe 4+1 view(考察绘图)
五种视图:
- 逻辑视图:描述了对架构而言重要的元素和他们之间的关系(功能需求)
- 过程视图:描述了元素之间的并发和交互
- 物理视图:描述了主要过程和组件是如何被映射到硬件上的
- 开发视图:描述了软件组件的内部组织联系(比如使用配置管理工具存储)
- 架构用例:捕获架构需求,与一个或多个特定视图相关。
质量属性建模
- 【必考】如何进行质量属性方案建模?请使用“刺激-响应”图的格式进行建模 How to model quality attribute scenarios? Graphically model one quality attributes in “stimulus-response” format:
如何进行质量属性方案建模:
- 刺激(Stimulus):到达系统时需要考虑的条件。
- 刺激源(Source of Stimulus):产生刺激的实体(人,系统或任何其他触发),可能是输入、信息等,对当前的状态的一个变化。
- 响应(Response):刺激到来后工件开展的行为。
- 响应度量(Response Measure):对刺激的响应以某种方法进行测量,以便可以测试需求(比如多长时间系统有反馈)
- 环境(Environment):发生刺激时系统的状况,例如系统正常运行、系统过载、系统受到攻击、系统网络出现故障等。
- 工件(Artifact):完成需求的整个系统或者系统的一部分(软件制品)。
QA Source of Stimulus Stimulus Artifact Environment Response Response Measure Availability【2015】【2017】【2018】 Heartbeat 监视器 服务器无响应 进程 正常操作 通知操作者继续操作 没有停机时间 Interoperability【2019】 车辆信息系统 发送当前位置 路况监控系统 系统在运行前已知 路况监控把当前位置和其他信息合并,覆盖 Google 地图上的,并进行广播 我们的信息在 99.99% 的时间是正确的 Modifiability【2017】【2018】【2019】 开发者 希望修改 UI 界面 代码 设计时 进行修改和单元测试 在 3 小时内 Performance【2015】 用户 发起事务 系统 正常操作 事务被处理 平均延迟不超过 2 秒 Security 远程的心怀不满的员工 尝试修改支付率 系统内数据 正常操作 系统维护审计追踪 正确数据在一天内被恢复,并且篡改源被识别 Testability 单元测试者 单元测试完成 单元测试代码 开发时 捕捉结果 3 小时内到达 85% 的路径覆盖 Usability 用户 下载新应用 系统 运行时 用户高效使用应用 在 2 分钟内完成实验
- 【2022】请将“可用性”定义为质量属性。MTBF 和 MTTR 代表什么?如何计算一个系统的可用性(例如,SLA)作为概率?Please define ‘Availability’ as a quality attribute. What do MTBF and MTTR stand for? How to calculate the availability of a system (e.g., SLA) as the probability? (6 points)
可将可用性计算为在指定的时间间隔内它将在要求的范围内提供指定服务的概率。
- MTBF(平均无故障时间,mean time between failures)
- MTTR(平均维修时间,mean time to repair)
$$
\frac{MTBF}{MTBF + MTTR}
$$
架构模式
- 【2015】【2017】【2018】什么区分了软件产品线架构和单个软件产品架构?What distinguishes an architecture for a software product line from an architecture for a single product?
- 产品线的目的:实现高可重用性、高修改性。
- 产品线之所以有效是因为通过重用可以充分利用产品的共性,从而产生经济性。
- 在产品线架构中有一组明确允许发生的变化,然而对于常规架构来说,只要满足了单个系统的行为和质量目标,几乎任何实例都是可以的。因此,识别允许的变化是架构责任的一部分,同时还需要提供内建的机制来实现它们。
- 【2015】【2019】解释代理架构模式的上下文、好处和局限性。Explain the context, benefits and limitations of Broker Architecture Pattern.
上下文:多个同步或异步交互的远程对象组成的系统,broker 模式已定义了运行时组件 broker,它协调多个客户机和服务器之间的通讯。
好处:
- 提高了 Client 和 Server 之间的交互性
- 提高可伸缩性和可扩展性
- 解决了单体应用的性能瓶颈
- 大规模集群的性能提高,但是单点性能会下降。
局限性:
- 代理增加了前期复杂度
- 可能成为通信的屏障
- 可能成为攻击的目标
- 难以测试
- 单点性能下降
SOA 延续了 broker 的思想,查找服务和使用服务都要通过 broker,而 SOA 只在查找时通过 register,分散了 broker 的职责,降低了单点风险。
- 【2018】Layered pattern 和 Multi-tier pattern 的区别
- Layered Pattern 是 Module Style,而 Multi-tier Pattern 是 Allocation Style
- Layered Pattern 是将任务拆解成一个个处于特定抽象级别的子层次,每层为下一层提供更高层次的服务,核心是关注点分离。
- Multi-tier Patten 中的层是逻辑的组合,没有层次模式的强依赖关系,在不同部署环境中分层不同但是软件完成的内容一致。
- 【2015】描述架构设计中架构模式和决策之间的关系。给出可以在架构设计过程中使用的任何四种决策的名称,并描述每种决策的目的。Describe the relationships between architectual patterns and tactics in architecture design. Give name of any four tactics that can be used during architecture design and describe the purpose of each of them.
架构模式与决策之间的关系:
- 决策比模式更简单,仅有单一的结构或机制来应对单一的架构驱动。
- 决策是构成架构模式的重要组成部分。
- 架构模式通常将许多个决策组合在一起。
- 大多数架构模式都包含不同的决策,这些决策可能有共同的目的或者常被用于实现不同的质量属性。
- 决策和架构模式共同构成了软件设计时的工具。
四种决策的名称:
- 【2015】简要描述面向服务架构(SOA)的基本原则,并讨论 SOA 对互操作性、可伸缩性和安全性等质量属性的影响 Briefly describe the fundamental principles of Service Oriented Architecture(SOA) and discuss the impact of SOA on quality attributes like interoperability, scalability and security
SOA 的基本原则:
- 服务契约:服务按照描述文档所定义的服务契约行事
- 服务封装:除了服务契约所描述内容,服务将对外部隐藏实现逻辑
- 服务重用:将逻辑分布在不同的服务中,以提高服务的重用性
- 服务组合:一组服务可以协调工作,组合起来形成定制组合业务需求
- 服务自治:服务对所封装的逻辑具有控制权
- 服务无状态:服务将一个活动所需保存的资讯最小化
SOA 对互操作性的影响:
- SOA 具有更高的互操作性:符合开放标准,可以更好的重用服务
- 支持服务的自动识别、发现、注册和调用等等
SOA 对可伸缩性的影响:
- SOA 具有更高的可伸缩性:服务自身高内聚、服务间松耦合,最小化维护的影响
- 但是 SOA 也会带来系统复杂度较高的问题
SOA 对安全性的影响:
- 中间件可能会成为性能的瓶颈
- ESB 等中间件都可以成为被攻击的目标
- 多服务导致攻击的跟踪、溯源和防御成为困难。
- 【2017】【不在授课范围】软件设计的三个变化维度,每个维度的变化点。不同的绑定时间如何影响可修改性和可测试性。
三个变化维度:
- 面向对象 OOP,强调重用性、灵活性和扩展性。
- 面向切面 AOP,满足扩展的需求,可以在程序中自由的扩展功能
- 面向服务 SOA,是系统发布功能的一种方式,且基于这种方式下不同的系统之间可以有效的沟通、协作。
设计时,开发时,测试时,发布时,运行时:这些绑定方式一次可修改性降低,可测试性升高
架构设计
- 【2017】【2019】什么是 ASR?列出提取和识别 ASR 的四种来源和方法。What are ASR? List four sources and methods for extracting and identifying ASRs.
ASR 架构攸关需求是对体系结构产生深远影响的需求。
四种来源和方法:
- 从需求文档中收集 ASR:MoSCoW 方法和用户故事
- 通过采访涉众来收集 ASR:质量属性工作坊(QAW)
- 通过了解业务目标来收集 ASR:
- 通过质量属性实体树(Utility Tree)来管理 ASR:通过方案量化描述需求后,逐渐对质量属性进行分解细化,直到包含量化指标为止。
- 【2018】【2022】Software requirements, Quality attributes, ASRs 的区别和联系
- 软件需求包括:功能性需求和非功能性需求(又称质量需求)
- 非功能性需求包括:技术限制、商业限制和质量属性
- 质量属性是由软件的业务目标所决定,在功能性需求的基础上提供的整个系统的合乎需求的特性,是非功能需求的一种反应。
- ASRs 架构攸关需求是对于体系结构有着深远影响的需求,肯定是软件需求的一部分。
- 【2018】描述 ADD 过程
- 确定有足够的需求信息
- 选择要分解的系统要素
- 确定所选的元素的 ASR
- 选择符合 ASR 的设计
- 找出设计问题
- 列出子关注点替代模式/决策
- 从清单中选择模式/决策
- 确定模式/决策与 ASR 之间的关系
- 记录初步的架构视图
- 评估并解决不一致的问题
- 实例化架构元素并分配职责
- 为实例化的元素定义接口
- 验证和细化需求并使它们成为实例化元素的约束
- 重复进行 2-7 步直到满足所有的 ASR
软件架构视图和文档化
- 【2015】【2017】【2019】【2022】为什么软件系统架构需要使用不同视图来文档化?给出 4 种示例视图的名称和目的。Why should a software architecture be documented using different different views? Give the name and purposes of 4 example views.
原因:
- 不同视图支持不同的目标和用户,突出不同的系统元素和关系
- 不同视图将不同质量属性暴露出不同的程度
4 种视图(了解):
- 结构视图:
Views Styles 描述 示例 Module Styles 它是如何构建为一组实现单元的?How it is structured as a set of implementation units? 分解视图、使用视图、泛化视图、分层视图、领域视图、数据模型视图 Component-connector(C&C) Styles 它是如何构建为一组具有运行时行为和交互的元素的?How it is structured as a set of elements that have runtime behavior and interactions? 管道-过滤器视图、客户端-服务器视图、点对点视图、面向服务视图、发布-订阅视图 Allocation Styles 它与环境中的非软件结构有何关系?How it relates to non-software structures in its environment? 部署视图、安装视图、工作分配视图、其他分配视图
- 质量视图 Quality Views,安全视图、性能视图、可靠性视图、通信视图、异常(错误处理)视图
- 组合视图:将上述视图进行组合
- 【2015】【2017】将以下每个问题(左侧)与解决该问题的架构风格/视图(右侧)对应起来。列出每个样式类别的四个视图。Map each of the following questions (on the left) with the architectural style/view (on the right) that addresses the question. List four views of each category of style.
见 2
- 【2017】【2019】典型的软件架构文档包中应该包含哪些内容?简要描述每个组件及其目的。What should be included in a typical software architecture documentation package? Briefly describe each component and its purpose.
文档应包含 View 和 Beyond 两部分内容。
- Beyond 部分:
- 文档路线图:包含了范围和总结、简单摘要等。
- 视图的文档组织方式:描述了本文档中视图是如何组织的。
- 系统概述:从整体上描述了当前架构的简要说明、业务目标(驱动因素)等等。
- 视图之间的映射关系:描述了不同视图之间的映射关系。
- 系统原理:从整体上描述了当前架构的设计原理。
- 目录-索引、词汇表、首字母缩略词表。
- View 部分:
- styles and views(体系结构风格和视图)
- Structural views
- module views
- C & C views
- Allocation views
- Quality Views
- 每一个 View 的内容:
- 主表示图:显示视图的元素和关系,以及图例
- 元素介绍:详细介绍第一部分中描述的元素、元素属性、关系属性和元素接口和行为。
- 上下文图:描述系统如何与环境相关
- 可变性指南:告知视图中可能出现的变化
- 基本原理:解释设计如何映射在视图中,以及其合理性。
架构评估
- 【2015】【2017】描述架构权衡分析方法(ATAM)过程的每个阶段生成的输出。Describe the outputs generated from each phase of Architecture Tradeoff Analysis Method(ATAM) process.
阶段 输出 参与者 职责 阶段-0:准备和建立团队 输入:架构设计文档
输出:评估计划评估团队领导和关键项目决策者 根据架构设计文档生成评估计划,包括谁参加评估、如何何时何地开展评估、最后评估报告会被呈递给谁。 阶段-1:评估-1 1. 架构的简明介绍
2. 业务目标(驱动因素)的阐释
3. 质量属性要求的优先级列表
4. Utility Tree 效用树
5. 风险和无风险点
6. 敏感和权衡点评估团队和项目决策者 第一步,评估负责人介绍 ATAM 方法
第二步,项目经理或客户从业务角度介绍业务驱动因素
第三步,首席架构师介绍体系结构
第四步,评估团队确定架构方法
第五步,评估团队和项目决策者生成质量属性效用树(Utiltiy Tree)
第六步,评估团队分析架构方法阶段-2:评估-2 1. 涉众们的优先级场景列表
2. 风险主题和每一个受到威胁的业务驱动因素评估团队、项目决策者和项目涉众 第一步,评估负责人介绍 ATAM 方法和之前已经取得的成果
第七步,涉众头脑风暴并确定场景优先级
第八步,评估团队分析架构方法,类似第六步
第九步,评估团队展示评估结果,并呈递给涉众阶段-3:后续 最终的评估报告 评估团队、主要涉众 评估团队制作最终评估报告,发给主要涉众审核通过后,将报告呈递给委托评估的人。
- 【2019】描述在 ATAM 的每一个过程中 有哪些 Stakeholder 和他们的职责
见上表
- 【2018】软件架构的关注点有哪些?利益相关方有哪些?
软件架构的关注点:
- 利益相关者 Stakeholders addressed
- 解决的问题 Concerns addressed
- 语言,建模技巧 Language, modeling techniques
- 决策,模式 Tactics, Pattern
利益相关方:
- 顾客 Customer
- 用户 User
- 架构师 Architect
- 需求工程师 Requirements engineer
- 设计师 Designer
- 实施者 Implementer
- 测试师,集成师 Tester, integrator
- 维护者 Maintainer
- 产品经理 Product manager
- 质量保证人 Quality assurance people
- 【2018】【2019】【2022】Risks,Senstivity Points,Trade-Off Points 分别是什么?各举一个例子。What are the risks, sensitivity points, and trade-off points associated with software architecture? Give an example for each of them.
- 识别风险:发现可能对所需质量属性产生负面影响的架构决策,例如使用分层模式可能带来性能损耗。
- 发现权衡:影响多个质量属性的架构决策,例如使用分层模式可能会带来性能损耗,但是也会解耦增加系统的可修改性。
- 发现敏感点:特定质量属性对其敏感的架构决策,比如在对性能敏感的系统中,决定使用缓存中间件。
微服务架构
- 【2019】微服务架构(MSA)和 SOA 的区别,相同点:
- 相同点:微服务和 SOA 都是分布式架构,微服务是 SOA 的一种扩展,都包含了服务契约、服务封装、服务重用、服务组合、服务自治和服务无状态等基本特点。
- 微服务去掉了 SOA 架构中的 ESB,采用轻量级通信机制(HTTP、REST)进行服务之间的通信。
- 微服务的管理和部署结合 DevOps 实现自动化,可以对服务进行自动化部署和监控预警。
- 微服务引入了 API 网关、对客户端屏蔽访问各项服务的问题。
- 微服务引入了熔断器:避免出现服务失效或网络问题等导致的级联故障。
- SOA 使用全局数据模型并共享数据库;MSA 每个服务有自己的数据模型和数据库
- SOA 服务是较大的单体应用;MSA 提供较小的服务
- 【2023 预测】微服务架构的主要特性:
- 通过服务组件化
- 服务内部高内聚,服务间低耦合
- 围绕业务能力组织,而不是聚焦在技术层面
- 去中心化
- 基础设施自动化
- 服务高可用性设计、演进式设计
- 每个服务相对较小并容易维护
- 服务可以独立扩展
- 技术栈不受限
- 大型复杂程序可以持续部署和交付
- 高可伸缩
软件详细设计简答题
- 【2017】请至少说出三个面向对象的原则,并解释它们如何应用于策略模式? Please name at least three Object-Oriented principles, and explain how they are applied in Strategy pattern?
- 单一职责原则
- 开闭原则
- 里氏代换原则
- 合成复用原则
- 【2019】设计模式是什么?举例说明类模式和对象模式的区别?
什么是设计模式:
- 设计模式是对被用来在特定场景下解决一般设计问题的类和互相通信的对象的描述,包括模式名称、问题、解决方案和效果四部分。
- 设计模式(Design Pattern)是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结,使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性。
设计模式分类
- 根据其目的(模式是用来做什么的)可分为创建型(Creational),结构型(Structural)和行为型(Behavioral)三种:
- 创建型模式主要用于创建对象。
- 结构型模式主要用于处理类或对象的组合。
- 行为型模式主要用于描述对类或对象怎样交互和怎样分配职责。
- 根据范围,即模式主要是用于处理类之间关系还是处理对象之间的关系,可分为类模式和对象模式两种:
- 类模式处理类和子类之间的关系,这些关系通过继承建立,在编译时刻就被确定下来,是属于静态的。
- 对象模式处理对象间的关系,这些关系在运行时刻变化,更具动态性。
- 【2019】防御式编程是什么?断言和错误处理的区别?
- 可以预见到(至少预先推测到)问题所在,断定代码中每个阶段可能出现的错误,并作出相应的防范措施,来防止类似的意外的发生。
- 断言和错误处理的区别
- 断言是在开发期间使用的、让程序在运行时进行自检的代码,是对开发人员的警告,通常是一个子程序或宏。断言不可以有副作用。
- 错误处理是对预先已经考虑到的错误(如用户错误、程序错误、意外情况等等)按照流程进行处理。
- 【2019】设计模式对 MVC 的影响?
- MVC 模式使用了运行时、动态和相互之间的关系集成到开发框架中,是分层模式的变种。
- 分为 model(业务逻辑)、view(处理用户展示,接收用户操作)、controller(对用户操作进行处理,将信息通知给 model)(强调模块间约束关系,model 不可以直接返回到 controller)
- 优点:耦合性低,重用性高,生命周期成本低,部署快,可维护性高,方便管理
- 缺点:没有明确定义,不适于中小型应用程序,增加实现复杂度,视图和控制器过于紧密,视图对模型访问低效。
- 四人书中,MVC 模式是观察者模式、策略模式和组合模式的演化,可能涉及到工厂模式和装饰器模式
- 基于推送-订阅模式
- 观察者:model 发生变化通知 controller,然后更新 view
- 策略模式:controllers 帮助 views 对不同用户的输入做不同的响应。
- 组合模式:一组 views
- 【2019】策略模式和状态模式的区别?
- 在状态模式中,具体状态类的方法参数中包含上下文对象,需要在状态处理完成后完成状态切换。
- 在策略模式中,直接对上下文类调用 set 方法设置策略即可,不涉及到策略的切换。
- 【2019】最小知识原则在设计模式中的应用?
- 中介者模式
- 外观模式
- 【2022】Please explain the Liskov Substitution Principle and how it contributes to the Open- Closed Principle. (6 points)
- 【2022】Please explain how the Factory Method Pattern and Abstract Factory Pattern adhere to the Open-Closed Principle. (6 points)
- 【2022】What is the benefit of decoupling the Receiver from the Invoker in the Command Pattern? (6 points)
4.There are two methods for propagating data to observers with the Observer design pattern: the push model and the pull model. Why would one model be preferable over the other? What are the trade-offs of each model? (6 points) - 【2022】What is the difference between the categories of Creational Patterns and Structural Patterns? What categories do Prototype and Flyweight fall into,respectively? Explain why.(6 points)
设计题
- 【2019】一个游戏,有几种人类角色:骑士、骑兵、步兵,持有不同的武器(矛、剑、斧),拥有 fight 方法;有一个非人类角色巨魔,可以持有武器,但攻击方法不同(beat)。现在希望让巨魔和其他人类角色一起进行游戏,并且要求有角色死亡时其他活着的角色要收到通知。运用设计模式进行设计,并画出类图。
classDiagram class Character { -name: string -weapon: Weapon +Character(name: string, weapon: Weapon) +getName(): string +getWeapon(): Weapon +notifyDeath(): void } class Human { +Human(name: string, weapon: string) +fight(): void } class Knight { +Knight(name: string, weapon: string) } class Cavalry { +Cavalry(name: string, weapon: string) } class Infantry { +Infantry(name: string, weapon: string) } class Troll { -name: string -weapon: Weapon +Troll(name: string, weapon: Weapon) +getName(): string +getWeapon(): Weapon +beat(): void +notifyDeath(): void } class Weapon { -type: string +Weapon(type: string) +getType(): string } class Game { -characters: Character[] +addCharacter(character: Character): void +removeCharacter(character: Character): void +startGame(): void +notifyDeath(character: Character): void } Character -- Weapon Character <|-- human <|-- knight cavalry infantry character troll game -- character< pre>
- 【2019】表驱动,参考 PPT 即可。
- 【2019】架构设计,没太看懂……大概是分析程序结构生成报告?
- 【2018】设计一个飞行模拟软件,要求能模拟多种飞机的特性。为了在将来支持更多飞机种类,要求使用策略模式。画出架构图和类图
- 【2019】一个买票系统的设计题,不同的角色有不同的打折方案,用策略模式设计, 最后画图,还要说明策略模式的使用场景。
【2015】【2019】
其他知识点
- 什么是软件系统架构:是结构和系统结构,包含了软件元素,这些组件的外部可视化属性和他们之间的关系(包含组件的行为)
- 几个概念
- 功能性需求:定义系统必须做什么,并且强调系统如何提供价值给涉众。
- 质量需求:系统应在功能性需求之上提供的整个系统的合乎需求的特性。
- 策略:是影响质量属性相应控制的设计决策,比如冗余。
- 架构模式
- 背景、上下文(Context):世界上经常发生问题的场景。
- 问题(Problem):在给定上下文中出现经过适当概括的问题。
- 解决方案(Element + Relations + Constraints):针对问题的成功的经过适当抽象的解决方案。
- ADD 的输出
- 软件元素:完成各种决策和职责、定义属性并与其他软件元素相关以组成系统架构的计算或开发工件。
- 角色:一组相关的职责。
- 职责:软件提供的功能、数据或信息。
- 属性:有关软件元素的附加信息。
- 关系:两个软件元素之间如何相互关联和交互的定义。
- 如何选择视图
- 构建涉众/视图表
- 合并视图
- 确定优先级和完成阶段
- 什么是微服务:是分布式架构,SOA 的一种扩展
- 微服务架构风格是一种将一个单一应用开发为一组小型服务的方法,每个服务运行在自己的进程中,服务间通信采用轻量级通信机制,这些服务围绕业务能力构建并可以通过自动部署机制独立部署。
- 微服务特点
- 服务颗粒化:服务粒度由业务功能决定,服务间尽可能解耦
- 责任单一化:单一职责原则,服务内尽可能内聚
- 运行隔离化:服务运行在各自进程中,互不影响
- 管理自动化:对服务提供自动化部署与监控预警能力,高效管理
- 微服务核心模式:针对采用微服务系统在特定问题所使用的程序的架构解决方案的集合
- 服务注册与发现
- API 网关
- 熔断器
- 微服务的挑战
- 运维要求高:微服务数量多,部署与监控要求高
- 发布复杂度:部署环境多样化,网络性能系统容错、分布式事务等挑战
- 部署依赖强:服务间相互调用关系复杂,存在部署顺序依赖
- 通信成本高:跨进程调用比进程内调用消耗更多的资源
- 面向对象设计原则
- 设计原则
- 目标:开闭原则
- 指导:最小知识原则
- 基础:单一职责原则、可变性封装原则
- 实现:依赖倒转原则、合成复用原则、里氏代换原则、接口隔离原则
- 模式一般都有的缺点
- 增加设计的复杂性和增加类的个数(增加辅助类)
- 增加隔阂、方法调用,降低软件运行的效率,但是已经不是目前主要的问题
- 引入设计模式的作用 1. 设计模式提供了与其他开发人员共享的词汇表。 2. 通过在模式级别(而不是实质性对象级别)进行思考,提高对体系结构的思考(但不要迷失在细节中)
- 防御式编程
- 防御式编程:可以预见到(或至少预先推测到)问题所在,断定代码中每个阶段可能出现的错误,并作出相应的防范措施,来防止类似意外的发生。
- 断言:在开发期间使用的、让程序在运行时进行自检的代码,是对开发人员的警告,通常是一个子程序或宏。断言不可以有副作用。
- 异常:是将代码中的错误或异常事件传递给调用方代码的一种特殊手段,谨慎使用可以降低复杂度。
- 错误处理:根据软件类别平衡正确性和健壮性(哪个优先级更高)
- 隔离程序:隔离程序是以防御式编程为目的而进行隔离的一种方法,将某些接口选定为“安全”区域的边界,对穿越安全区域边界的数据进行合法性检验(集中工作在特定的模块中降成本)
- 辅助调试代码:辅助进行代码调试的代码,帮助快速检查错误,应该尽早地引入辅助调试代码。
- 攻击式编程:主动暴露出可能出现的错误,在开发阶段将其暴露显现出来,而在产品代码运行时让他能够自我恢复。
- 表驱动法:一种编程模式
- 目的:表驱动法适用于复杂逻辑,将复杂逻辑从代码中独立出来方便单独维护
- 原理:从表里面查找信息而不使用逻辑语句(if 和 else)
- 具体实现
- 直接访问表:直接通过索引值可以从表中找到对应的条目
- 索引访问表:首先从索引表中找到数据表的地址,然后再从数据表中找到对应的条目(节省空间、管理廉价、容易维护)
- 阶梯访问表:根据每项命中的阶梯层次来确定其归属
- 装饰者的两个缺点:很多小类、难以排查错误
- 增加新的鸭叫统计次数(不允许修改原本代码):装饰器模式
选择模式
- 一个温度系统有 3 个恒温器,一个恒温器可以调整和显示温度,2 个恒温器只能手动调节,1 个恒温器可以手动、计时器调节:中介者、策略
- 模板方法:先调整、再显示(用户直接复用模板方法,而本例中复用的是实现)
- 一个队伍有 1 个管理者和 25 个队员,每一个队员可以有一个位置,有的特别强的队员可以有多个位置:策略、原型
- 策略独立于 Player,所以 Player 是一样的
- 模板方法模式是解决步骤的问题
- 积分会员制,积分比较高则为高级会员,积分比较低则为低级会员
What is a Pattern? Match each pattern with its description:
A:Adapter B:State C:Iterator D: Facade E: Strategy F: Observer G: Factory Method H: Decorator I:Command J: Template Method K: Composite L: Singleton
描述 | 模式 |
---|---|
Wraps an object and provides a different interface to it. | 适配器模式 |
Subclasses decide how to implement steps in an algorithm. | 模板方法模式 |
Subclasses decide which concrete classes to create. | 工厂方法模式 |
Ensures one and only one objectis created. | 单例模式 |
Encapsulates interchangeable behaviors and use delegation to decide which one to use. | 策略模式 |
Clients treat collections of objects and individual objects uniformly. | 组合模式 |
Encapsulates state-based behaviors and use delegation to switch between behaviors. | 状态模式 |
Provides a way to traverse a collection of objects without exposing its implementation. | 迭代器模式? |
Simplifies the interface of a set of classes. | 外观模式 |
Wraps an object to provide new behavior. | 装饰模式 |
Allows objects to be notified when state changes. | 观察者模式 |
Encapsulate a request as an object. | 命令模式 |