关于SOA和微服务

面向服务的架构(SOA)

想象一下,你正在经营一家大型超市,超市里有各种各样的商品和服务。SOA 就像是超市的各个部门,比如生鲜区、家电区、收银台等等,每个部门提供特定的服务。这些服务(部门)通过一定的规则(如通信协议)相互协作,共同为顾客(即应用程序或用户)提供服务。在 SOA 中,服务的粒度可能比较大,一个服务可能包含多个功能,比如生鲜区可能同时提供蔬菜、水果和肉类的服务。

微服务

现在,让我们把这个超市变成一个市场,市场里有许多小摊位,每个摊位只卖一种东西,比如一个摊位只卖苹果,另一个只卖香蕉。这就是微服务的理念------每个服务都非常小,只负责一项具体的任务,而且这些服务是独立的,可以单独部署、扩展和升级。这就像市场里的摊位,你可以随时调整某个摊位的商品而不影响其他摊位。

微服务与 SOA 的关系

微服务可以看作是 SOA 的一个子集或一种进化,它继承了 SOA 的面向服务的原则,但是将服务的粒度细化到了极致。在微服务架构中,服务的边界更加清晰,每个服务只做一件事,这使得系统更加灵活、易于扩展和维护。

总结

  • SOA 是一个更广泛的概念,涵盖了多种服务架构的风格,服务的粒度可以从较大到较小。
  • 微服务 是 SOA 的一个特例,它强调极小的服务粒度,每个服务只关注单一职责,独立部署和扩展。

所以,微服务确实是面向服务架构的一种,但它通过进一步细化服务的粒度,实现了更高的灵活性和可维护性。

区别概要

思想上:微服务的目的是解耦而SOA的目的是实现数据的互通和共享性。

协议:微服务会使用一些轻量级的通信协议(Restful API)

基础设施要求,微服务更加强调开发运维的持续交付。

相关推荐
Aaron15889 分钟前
三种主流接收机架构(超外差、零中频、射频直采)对比及发展趋势浅析
c语言·人工智能·算法·fpga开发·架构·硬件架构·信号处理
csdn_aspnet11 分钟前
使用 RabbitMQ 和 MassTransit 在 .NET Core 中实现强大的微服务:处理订阅者故障和消息恢复
微服务·rabbitmq·.netcore
Wilson Chen22 分钟前
从“手搓”到云原生:某 B2B 平台服装 AI 搜索架构演进实战
人工智能·云原生·架构
Elastic 中国社区官方博客9 小时前
使用 Elastic Cloud Serverless 扩展批量索引
大数据·运维·数据库·elasticsearch·搜索引擎·云原生·serverless
Tadas-Gao10 小时前
AI是否存在“系统一”与“系统二”?——从认知科学到深度学习架构的跨学科解读
人工智能·架构·系统架构·大模型·llm
南宫乘风10 小时前
Kubernetes 本地存储实战:Open-Local 从部署到生产级应用
云原生·容器·kubernetes
程序员JerrySUN12 小时前
OP-TEE + YOLOv8:从“加密权重”到“内存中解密并推理”的完整实战记录
android·java·开发语言·redis·yolo·架构
ZStack开发者社区14 小时前
替代VMware VCF | 详解ZStack Cloud开放架构与异构整合能力
架构
小股虫16 小时前
分布式事务:在增长中台,我们如何做到“发出去的内容”和“记录的数据”不打架?
分布式·微服务·云原生·架构·团队建设·方法论
忧郁蓝调2617 小时前
Redis不停机数据迁移:基于 redis-shake 的跨实例 / 跨集群同步方案
运维·数据库·redis·阿里云·缓存·云原生·paas