优点:开发起来容易 缺点:代码耦合度高,后期维护较为困难
集中式的架构是无法应对高并发的业务,所有请求都走一个模块,所以垂直拆分是根据业务功能对系统进行拆分
优点:解决了并发问题,可以对不同的模块进行优化 缺点:虽然对个业务进行了拆分,但还是存在许多的重复开发
#分布式服务 将拆分出来的模块,核心业务或者相同的业务拆分出来,作为独立的服务
优点:提高了代码复用和开发效率 缺点:系统之间的耦合度变高,调用关系也比较复杂,难以维护
服务之间通过相互依赖最终提供一系列功能,一个服务通常以独立的形式存在与操作系统进程中,各个服务通过网络进行调用
微服务架构是使用一套小服务来开发单个应用的方式或途径,每个服务基于单一业务能力构建,运行在自己的进程 中,并使用轻量级机制通信,通常是HTTP API,并能够通过自动化部署机制来独立部署。这些服务可以使用不同的编程语言实现,以及不同数据存储技术,并保持最低限度的集中式管理
微服务的特点:
微服务架构与SOA都是对系统进行拆分;微服务架构基于SOA思想,可以把微服务当做去除了ESB的SOA。ESB是 SOA架构中的中心总线,设计图形应该是星形的,而微服务是去中心化的分布式软件架构。两者比较类似,但其实也 有一些差别:
功能 | SOA | 微服务 |
---|---|---|
组件大小 | 大块业务逻辑 | 单独任务或小块业务逻辑 |
耦合 | 通常松耦合 | 总是松耦合 |
管理 | 着重中央管理 | 着重分散管理 |
目标 | 确保应用能够交互操作 | 易维护、易扩展、更轻量级的交互 |