学习SpringCloudAlibaba(二)微服务的拆分与编写

目录

一、单体架构VS微服务架构

1.单体架构

​(1).单体架构的优点

(2).单体架构的缺点

 2.微服务架构

 (1)微服务的特性

 (2)微服务架构图

 (3)微服务的优点

 (4)微服务的缺点

 (5)微服务适用场景

扫描二维码关注公众号,回复: 16773522 查看本文章

 (6)微服务不适用场景 

二、微服务拆分

1. 微服务拆分--方法论

(1)领域驱动设计(Domain Driven Design)

(2)面向对象(By name / by verb) 

2 微服务拆分--常用

(1)按职责划分

(2)按通用性划分

3 微服务拆分--合理的粒度

三、实际项目流程


一、单体架构VS微服务架构

1.单体架构

(1).单体架构的优点

  • 架构简单
  • 开发、测试、部署方便

(2).单体架构的缺点

  • 代码冗余,质量参差不齐,导致运维复杂性高
  • 部署慢,全量部署,频率低,代码量大时,更加明显
  • 扩展能力受限
  • 阻碍技术创新,代码重构风险极高

 2.微服务架构

 (1)微服务的特性

  • 每个微服务可运行在自己的进程中,意味着每个微服务都有自己的tomcat
  • 每个微服务都能独立运行,共同构建整个系统
  • 每个服务为独立的业务开发,一个微服务只关注某个特定的功能,例如订单管理、用户管理。
  • 可使用不同的语言与数据存储技术(契合项目的情况和团队实力)
  • 微服务之间通过轻量的通信机制进行通信,例如通过REST API进行调用。轻量通信机制,通信协议需要轻量,跨平台
  • 全自动的部署机制。自动化构建、部署、测试等等。

 (2)微服务架构图

  (3)微服务的优点

  • 单个服务更易于开发/维护,单个服务是有限的业务。
  • 单个微服务启动较快
  • 局部修改易于部署
  • 技术栈不受限
  • 按需伸缩

 (4)微服务的缺点

  • 运维要求高,运维若干个jar,所以需要全自动的运维部署机制
  • 分布式固有的复杂性
  • 重复劳动,在相同开发语言下,可以提取一共公共模块,而不同语言是无法实现,还是得重复

 (5)微服务适用场景

  • 大型/复杂的项目。如果你的应用用单体架构可以搞定了,就无需杀鸡用牛刀。
  • 有快速迭代的需求
  • 访问压力大的,微服务是去中心化的。

 (6)微服务不适用场景 

  • 业务稳定,需求几乎不会变
  • 迭代周期长,没有快速迭代的需求

二、微服务拆分

1. 微服务拆分--方法论

(1)领域驱动设计(Domain Driven Design)

推荐两本书:

《DDD的开山鼻祖》

《实现领域驱动设计》

(2)面向对象(By name / by verb) 

通过名词或动词拆分

2 微服务拆分--常用

(1)按职责划分

规划好微服务的职责边界,只关注职责范围内的业务,比如订单服务

(2)按通用性划分

把通用性功能做成微服务,比如用户中心,消息中心, 阿里的大中台与小中台其实也是按通用性,只是中台是多个微服务的聚合。

3 微服务拆分--合理的粒度

  • 良好地满足业务
  • 幸福感,团队对微服务的维护不会觉得像单体一样冗余复杂,部署也会高效
  • 增量迭代,每个微服务相对独立,每次发布只是有限的微服务
  • 持续进化,技术优化,风险可控
  • 微服务拆分是动态的,可以会随着时间增减

三、实际项目流程

1、分析业务(流程图、用例图、架构图等等),主要任务是业务建模,确定架构

2、确定业务流程(评审)

3.设计API(我需要哪些API呢)/数据模型(表结构设计|类图|ER图等等)

4.编写API

猜你喜欢

转载自blog.csdn.net/heni6560/article/details/128846305