系统架构设计师—系统架构设计篇—SOA架构

文章目录

概述

面向服务的架构(service-oriented Architecture,SOA),就是如何"基于服务"或"基于一堆服务"来实现的业务架构。

面向服务是在面向对象的基础上发展而来的,但服务和对象有所不同:

  • 对象主要是面向系统的,而服务是面向业务的。
  • 对象的粒度级别主要集中在类级,而服务是粗粒度的。
  • 类是以函数调用为基础来交互的,而服务是以网络请求为基础来交互的。

SOA

关于服务,一些常见的设计原则有:明确定义的接口自包含模块化粗粒度松耦合互操作性

SOA紧密相关的基数主要有UDDIWSDLSOAP,而这些技术都是以XML为基础而发展起来的。

  • UDDI:一种用于描述、发现、集成Web Service的技术。
    • 通过UDDI,企业可以根据自己的需要动态查找并使用Web服务。
    • 也可以将自己的Web服务动态地发布到UDDI注册中心,供其他用户使用。
  • WSDL:Web服务描述语言,是为描述Web服务发布的XML格式。
  • SOAP:简单对象访问协议是交换数据的一种协议规范,是一种轻量的、简单的、基于XML的协议,它被设计成在Web上交互结构化的和固化的信息。

实现方式

服务注册表模式

SOA VS SOAP

SOA指的是架构方法及流程,WebService(服务提供者)、UDDI(注册中心)、业务方(调用方、消费者)三者的地位、作用以及需要遵从的执行流程:

  • WebService将自己的WSDL注册给UDDI。
  • 业务方先从UDDI获取到WSDL,进而才能访问WebService。

SOAP指的是SOA的三个组件互相访问时遵从的网络协议,即:用HTTP请求承载,XML为组织格式,来传递输入输出的有约束的数据。

企业服务总线模式(ESB)

Enterprise Service Bus,企业服务总线架构模式在于整合,可能是公司内部各团队的服务,也可能是公司之间的不同服务,组成一个整体,来向外提供服务。

业务方只跟业务总线交互:

  • 业务方将请求提交给业务总线。
  • 由业务总线转发请求给相应的后端服务。
  • 业务总线收到回复后再转发给业务方。

即,业务总线也兼具"代理"的功能。业务方只需要知晓业务总线的地址,无需耦合所有服务。

主要作用

  1. SOA的一种实现方式,ESB在面向服务的架构中起到的是总线作用,将各种服务进行连接与整合。
  2. 描述服务的元数据和服务注册管理。
  3. 在服务请求者和提供者之间传递数据,以及对这些数据进行转化的能力,并支持由实践中总结出来的一些模式如同步模式、异步模式等。
  4. 发现、路由、匹配和选择的能力,以支持服务之间的动态交互,解耦服务请求者和服务提供者。高级一些的能力,包括对安全的支持、服务质量保证、可管理性和负载平衡等。
相关推荐
码点滴9 小时前
什么时候用 DeepSeek V4,而不是 GPT-5/Claude/Gemini?
人工智能·gpt·架构·大模型·deepseek
heimeiyingwang9 小时前
【架构实战】状态机架构:订单/工单状态流转设计
观察者模式·架构·wpf
小江的记录本10 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
一切皆是因缘际会10 小时前
AI数字分身的底层原理:破解意识、自我与人格复刻的核心难题
大数据·人工智能·ai·架构
jinanwuhuaguo12 小时前
(第二十七篇)OpenClaw四月的演化风暴:OpenClaw 2026年4月全版本更新的文明级解读
大数据·人工智能·架构·kotlin·openclaw
James_WangA12 小时前
我给 AOI 设备装了一个 Agent,然后发现工具注册才是最难写的
架构·github
James_WangA12 小时前
产线上跑 Agent:LLM 挂了不是 500 错误,是停线
架构·github
生成论实验室13 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
SamDeepThinking13 小时前
并发量就算只有2,该上锁还得上呀
java·后端·架构
Sam_Deep_Thinking14 小时前
如何让订单系统和营销系统解耦
java·架构·系统架构