【架构-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 分钟前
如何在postman中动态请求k8s中的pod ip(基于nacos)
云原生·容器·kubernetes
vivo互联网技术5 分钟前
号码生成系统的创新实践:游戏周周乐幸运码设计
redis·后端·架构
泡泡_022410 分钟前
云原生系统DOCKER中容器系统搭建
docker·云原生·容器
Java技术小馆18 分钟前
POST为什么发送两次请求
java·面试·架构
百度Geek说28 分钟前
搜索数据建设系列之数据架构重构
数据仓库·重构·架构·spark·dubbo
DemonAvenger29 分钟前
Go内存压力测试:模拟与应对高负载的技术文章
性能优化·架构·go
DemonAvenger34 分钟前
从C/C++迁移到Go:内存管理思维转变
性能优化·架构·go
云妙算38 分钟前
K8s 弹性伸缩踩坑实录:周末 2 天烧掉 10 万元!?
云原生·kubernetes
大只鹅39 分钟前
两级缓存 Caffeine + Redis 架构:原理、实现与实践
redis·缓存·架构
数据智能老司机1 小时前
Linux内核编程——字符设备驱动程序
linux·架构·操作系统