6. 软件架构的演进过程

1.软件架构的演进过程

1.1单一应用架构(ORM)

当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。此时,用于简化增删改查工作量的数据访问框架(ORM)是关键

  架构说明:全部功能集中在一个项目中

  架构优点:架构简单,前期开发成本低,开发周期短,适合小型项目

  架构缺点:全部功能集中在一个项目中,对于大型项目不易开发,扩展和维护,技术栈受限,只能使用一种语言开发

  系统性能扩展只能通过扩展集群节点,成本高

1.2 垂直应用架构

当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,提升效率的方法之一是将应用拆成互不相干的几个应用,以提升效率。此时,用于加速前端页面开发的Web框架(MVC)是关键

架构说明:按照业务进行切割,形成小的单体项目

架构优点:技术栈可扩展(不同的系统可以用不同的编程语言写)

架构缺点:功能集中在一个项目中,不利于开发扩展,维护,系统扩张只能通过集群方式,项目之间,功能冗余,数据冗余,耦合性强

1.3分布式服务架构

当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。此时,用于提高业务复用及整合的分布式服务框架(RPC)是关键

1.4 流动计算架构(SOA)

当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。此时,用于提高机器利用率的资源调度和治理中心(SOA)是关键。

1.5微服务架构

架构说明:

  将系统服务层完全独立出来,抽取为一个个的微服务

  抽取粒度更细,遵循单一职责,采用轻量化框架协议传输

架构优点:

  服务拆分粒度更细,有利于提高开发效率,可以针对不同服务定制对应的优化方案

  适用于互联网时代,产品迭代周期更短

架构缺点:

  粒度太细导致服务太多,维护成本高

  分布式系统开发技术成本高,对团队挑战大

posted @ 2022-08-01 20:06  努力的达子  阅读(172)  评论(0编辑  收藏  举报