【架构-11】SOA和微服务?

什么是SOA?

SOA是面向服务的架构,是一种软件架构模式,旨在通过将应用程序拆分成可重用的服务来提高应用程序的灵活性、可维护性和可扩展性。它将应用程序的不同功能单元(称为服务)通过这些服务之间良好的接口联系起来。

什么是ESB?

SOA中心化的实现方式就是ESB,企业服务总线,像是一根管线,用于连接各个节点。为了集成不同系统,不同协议的服务,ESB做了消息的转换解释和路由等工作,让不同的服务互联。

特点:(1)SOA的实现方式,总线作用,服务连接和整合(2)服务注册管理(3)发现、路由和转换解释(4)传递数据、数据转换、同步、异步

什么是微服务架构?

微服务架构将软件应用程序分成一系列小型的、松耦合的服务模块,每个服务都专注于执行特定的业务功能,通过轻量级的通信机制相互通信,从而形成一个完整的应用系统。每个子系统都是独立的且完整的。
优点 :(1)模块化,松耦合,功能模块间影响少(2)可扩展性、可维护性强(3)技术栈多样性(4)独立部署和伸缩性(5)容错
缺点:(1)服务间的通信开销(2)分布式系统的复杂性(3)数据管理的一致性问题

SOA与微服务的区别

(1)微服务比SOA更加精细,微服务以更多的独立进程的方式存在,互相之间并无影响,而SOA的目标是确保应用能够交互操作。

(2)微服务的接口方式更加通用化,例如Http Restful方式,任何终端可调用,无关平台与语言限制

(3)微服务更倾向于去中心化的部署方式,在互联网业务场景下更适合。

(4)组件大小:SOA是大块业务逻辑,微服务是单独任务或小块业务逻辑。

(5)SOA着重中央管理,微服务着重分散管理。

相关推荐
啊森要自信2 小时前
CANN ops-cv:面向计算机视觉的 AI 硬件端高效算子库核心架构与开发逻辑
人工智能·计算机视觉·架构·cann
2的n次方_3 小时前
CANN ascend-transformer-boost 架构解析:融合注意力算子管线、长序列分块策略与图引擎协同机制
深度学习·架构·transformer
Gold Steps.4 小时前
OpenEBS — 云原生 CNS 高性能存储
云原生·kubernetes·存储
瑶山4 小时前
Spring Cloud微服务搭建四、集成RocketMQ消息队列
java·spring cloud·微服务·rocketmq·dashboard
Fushize4 小时前
多模块架构下的依赖治理:如何避免 Gradle 依赖地狱
android·架构·kotlin
大雨淅淅5 小时前
Eureka从入门到精通:开启微服务架构的钥匙
微服务·云原生·eureka·架构
qq_404643345 小时前
Eureka 核心概念
微服务·eureka
AI架构全栈开发实战笔记5 小时前
Eureka 对大数据领域服务依赖关系的梳理
大数据·ai·云原生·eureka
狗哥哥6 小时前
微前端路由设计方案 & 子应用管理保活
前端·架构
岁岁种桃花儿6 小时前
SpringCloud从入门到上天:Nacos做微服务注册中心(二)
java·spring cloud·微服务