当前位置: 首页 > news >正文

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

目录

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

1.单体架构

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

(2).单体架构的缺点

 2.微服务架构

 (1)微服务的特性

 (2)微服务架构图

 (3)微服务的优点

 (4)微服务的缺点

 (5)微服务适用场景

 (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

http://www.lryc.cn/news/1787.html

相关文章:

  • 通过对HashMap的源码分析解决部分关于HashMap的问题
  • 【无标题】
  • 渗透测试 -- 网站信息收集
  • Windows 搭建ARM虚拟机 UOS系统
  • day58每日温度_下一个更大元素1
  • 超清遥感影像语义分割处理
  • RabbitMQ安装及配置
  • 网络协议(四):网络互联模型、物理层、数据链路层
  • 请问有没有关于数据预测的方法?
  • [CVPR 2021] Your “Flamingo“ is My “Bird“: Fine-Grained, or Not
  • clickHouse笔记
  • 10.jQuery中请求预处理 $.ajaxPrefilter()
  • 【黄啊码】浅谈PHP入门|如何学习PHP
  • 人大金仓数据库的归档日志
  • C++:类和对象(上)
  • 数据库 与 数据仓库的本质区别是什么?
  • 数据库实践LAB大纲 05 JDBC 连接
  • Linux部署nuxt3
  • 鸟哥的Linux私房菜读书笔记:文件系统的简单操作
  • 论如何用python自动下载爱的妹子视频~嘿嘿嘿~
  • 传奇GOM引擎配置PAK密码补丁教程
  • 邀您参赛!DCIC 2023「科技金融欺诈风险识别」算法赛正在报名中
  • ElasticSearch-学习笔记04【Java客户端操作索引库】
  • 低代码开发平台|制造管理-工艺工序搭建指南
  • Window 安装 Docker
  • 最近很火的一部电视(狂飙)像安欣和高启强这样类型的人,谁更合适做软件测试工程师
  • LSTM已死,Transformer当立(LSTM is dead. Long Live Transformers! ):上
  • 今天面试招了个18K的人,从腾讯出来的果然都有两把刷子···
  • 洛谷 P5764 [CQOI2005]新年好
  • 【自然语言处理】主题建模:BERTopic(实战篇)