【架构-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着重中央管理,微服务着重分散管理。

相关推荐
想进大厂的小王10 分钟前
Spring-cloud 微服务 服务注册_服务发现-Eureka
微服务·eureka·服务发现
景天科技苑18 分钟前
【云原生开发】K8S多集群资源管理平台架构设计
云原生·容器·kubernetes·k8s·云原生开发·k8s管理系统
wclass-zhengge1 小时前
K8S篇(基本介绍)
云原生·容器·kubernetes
颜淡慕潇1 小时前
【K8S问题系列 |1 】Kubernetes 中 NodePort 类型的 Service 无法访问【已解决】
后端·云原生·容器·kubernetes·问题解决
W Y3 小时前
【架构-37】Spark和Flink
架构·flink·spark
Gemini19954 小时前
分布式和微服务的区别
分布式·微服务·架构
昌sit!9 小时前
K8S node节点没有相应的pod镜像运行故障处理办法
云原生·容器·kubernetes
Dann Hiroaki12 小时前
GPU架构概述
架构
茶馆大橘12 小时前
微服务系列五:避免雪崩问题的限流、隔离、熔断措施
java·jmeter·spring cloud·微服务·云原生·架构·sentinel
北漂IT民工_程序员_ZG13 小时前
k8s集群安装(minikube)
云原生·容器·kubernetes