单体架构
将业务所有功能集中在一个项目中开发,打成一个包部署
优点:架构简单,部署成本低
缺陷:耦合度高
分布式架构
根据业务功能对系统进行拆分,每个业务作为独立项目开发,成为一个服务
优点:降低服务耦合,有利于服务升级拓展
分布式架构要考虑的问题
- 服务拆分粒度,
- 服务集群地址如何维护,
- 服务之间如何实现远程调用,
- 服务健康状态如何感知
微服务
微服务是一种经过良好架构设计的分布式架构方案
特征
- 单一职责:微服务拆分粒度更小,每个服务对应唯一的业务能力,做到单一职责,避免重复业务开发
- 面向服务:微服务对外暴露业务接口
- 自治:团队独立,技术独立,数据独立,部署独立
- 隔离性强:服务调用做好隔离,容错,降级,避免出现级联问题
数据独立每个服务有自己独立的数据库