加入收藏 | 设为首页 | 会员中心 | 我要投稿 常州站长网 (https://www.0519zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长资讯 > 动态 > 正文

软件架构的一切

发布时间:2021-04-06 16:01:02 所属栏目:动态 来源:互联网
导读:时间的推移,这种项目变得难以管理,因此每次新迭代都会大大增加维护成本。这限制了软件的发展,超出了项目开始时最初定义的范围。 在软件设计的多年发展过程中,开发人员提出了一些健壮的体系结构方法,以避免出现少体系结构的软件设计问题(也称为泥泞大球)

时间的推移,这种项目变得难以管理,因此每次新迭代都会大大增加维护成本。这限制了软件的发展,超出了项目开始时最初定义的范围。

在软件设计的多年发展过程中,开发人员提出了一些健壮的体系结构方法,以避免出现少体系结构的软件设计问题(也称为“泥泞大球”)。以下是一些最著名的

  • 分层架构
  • 多层架构
  • 面向服务的体系结构(SOA)
  • 微服务架构

分层架构

此方法基于关注点分离的原理。软件设计分为相互重叠的一层。每一层都承担着专门的责任。架构将软件分为以下几层

  • 表示层
  • 业务逻辑层
  • 数据链路层

表示层拥有与外界交互的用户界面。这也负责提供用户体验,因为这是暴露给最终用户交互的唯一层。

顾名思义,业务逻辑层包含软件应用程序的业务逻辑。该层将UI / UX与业务相关的计算分离开,从而提供了根据不断变化的业务需求修改逻辑的灵活性,而不会影响其他层。

数据链接层负责与数据库等持久性存储进行交互以及与域无关的杂项数据处理(即与业务无关)。

数据和控制从设计的每一层流到另一层。这些层还增加了设计中的抽象度。由于稳定性在一定程度上与抽象成正比,因此也将软件的稳定性提高到一定程度。

  • 层之间的关注点分离而提供抽象
  • 层之间的隔离使其他层免受一层的修改
  • 由于耦合度低,软件变得更易于管理

坏处:

  • 没有太大的可扩展性
  • 用这种方法构建的软件将倾向于具有缺乏易于修改的单体结构
  • 即使没有必要从某些层传递数据,数据也必须一层一层地从另一层流出。此问题被称为“污水池问题”

多层架构

这种架构方法根据客户端服务器通信原理将软件套件分为几层。架构可以具有n层系统中的一,二层,将数据提供者和使用者之间的职责分开。

它利用请求响应模式在定义的层之间进行通信。与分层架构不同,它提供的可伸缩性可以是水平的(通过高性能节点扩展网络)或垂直的(通过提高单个性能来扩展每个节点)

单层系统

在这种方法中,单个系统既可以充当客户端又可以充当服务器,并且可以简化部署,而无需进行系统间通信(ISC)。因此,提供了很好的通信速度。

这样的系统仅适用于小规模的单用户应用程序,而不应用于多用户复杂的应用程

(编辑:常州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读