《分布式服务架构:原理、设计与实战》

1 分布式微服务架构设计原理

1.1 从传统单体架构到服务化架构

JEE架构
针对企业级应用定义,进行了逻辑分层,包括Web层、业务逻辑层、数据存取层,大多数项目仍然部署在同一个应用服务器上的一个JVM进程中。

SSH架构
仍然以服务企业级用户为主,分为三个层次:实现UI交互的Web MVC层、实现业务逻辑的Spring层及实现对象对象关系映射的Hibernate层,与JEE对应层次对比层次更简单,实现更轻量级,提高了开发效率,但大多数仍然部署在同一个应用服务器上的一个JVM进程中。

由于无法处理海量用户发起的高并发请求,无法突破耦合在一起的模块化组件的性能瓶颈,水平扩展的提升也有限。
为了解决上述问题,SOA出现了。

服务化架构
将模块化组件从单一进程中进一步拆分,形成独立的对外提供服务的网络化组件,每个组件通过某种网络协议对外提供服务。
这种架构的特点如下:

  • 服务间表现为松耦合性,可以对服务流程进行灵活组装和编排
  • 服务内部实现对外部来说是透明的,对外接口保持不变,服务可独立开发管理
  • SOA通过定义标准的对外接口,可以让底层通用服务下沉,供多个上层服务使用,增加服务的可重用性
  • 最大化的使用内部或外部的公共服务,避免重复早轮子。

你可能感兴趣的:(读书笔记)