软件架构的演变-单体架构,垂直架构,分布式架构,SOA架构和微服务架构的演变历程

软件架构的发展经历了从单体架构、垂直架构、SOA架构到微服务架构的过程,作为一个80年代的程序员,今天燕青跟大家说说具体的经历。

单体架构

Web应用程序发展的早期,大部分web工程师将所有的功能模块打包到一起并放在一个web容器中运行,所有功能模块使用同一个数据库。

下图是一个单体架构的电商系统:

1、按业务垂直拆分成一个一个的单体系统,此架构也称为垂直架构。

2、系统与系统之间的存在数据冗余,耦合性较大,如上图中三个项目都存在客户信息。

3、系统之间的接口多为实现数据同步,如上图中三个项目要同步客户信息。

优点:

1、通过垂直拆分,每个子系统变成小型系统,功能简单,前期开发成本低,周期短。

2、每个子系统可按需伸缩。

3、每个子系统可采用不同的技术。

缺点:

1、子系统之间存在数据冗余、功能冗余,耦合性高。

2、按需伸缩粒度不够,对同一个子系统中的不同的业务无法实现,比如订单管理和用户管理。

SOA架构

SOA是一种面向服务的架构,基于分布式架构,它将不同业务功能按服务进行拆分,并通过这些服务之间定义良好的接口和协议联系起来。

1、服务层按业务拆分为一个一个的微服务。

2、微服务的职责单一。

3、微服务之间采用RESTful、RPC等轻量级协议传输。

4、有利于采用前后端分离架构。

优点:

1、服务拆分粒度更细,有利于资源重复利用,提高开发效率。

2、可以更加精准的制定每个服务的优化方案,按需伸缩。

3、适用于互联 时代,产品迭代周期更短。

缺点:

1、开发的复杂性增加,因为一个业务流程需要多个微服务通过 络交互来完成。

2、微服务过多,服务治理成本高,不利于系统维护。

文章知识点与官方知识档案匹配,可进一步学习相关知识云原生入门技能树首页概览8825 人正在系统学习中

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2019年10月22日
下一篇 2019年10月22日

相关推荐