SOA

[size=large]SOA 架构[/size]

SOA,面向服务架构,它强调系统之间以标准的服务方式进行交互,各系统可以采用不同的语言、不同的框架来实现,交互则全部通过服务的方式进行。


缺点:
1.服务多级调用的延迟,a->b,b->c,这样会带来大幅度的延迟。
2.调试\跟踪困难
3.更高的安全/监测要求
4.现有应用移植
5.Qos的支持
每个服务提供者能够支撑的访问量是有限的,因此设定服务的Qos非常重要,尽可能的采取一系列措施来保障Qos,如流量控制、机器资源分配。
6.高可用和高可伸缩
7.多版本和依赖管理


从标准上看,SCA提供了清晰的发布服务、调用服务及无缝和现有应用集成的支持。
在调试/跟踪的支持上SCA标准中没有明确的定义,依赖管理上也没有明确的定义。
ESB和SCA不同,它并不是由多个厂家联合指定的SOA实现标准,可以认为ESB只是个概念,核心思想是基于消息中间件来实现系统间的交互。系统间交互的数据格式采用统一的消息格式,由总线完成消息的转化、路由,发到相应的目标应用。
在统一服务调用方式上,可以认为ESB中的消息方式承担了这一功能,且支持多种通信及交互(同步、异步)方式,在调试/跟踪支持上没有定义,在依赖管理上,由于所有交互都通过总线来进行,可以根据消息的流转来判断和形成各个系统的依赖关系。在高性能和高可用这两点上,则取决于实现框架。
04-24
### 关于 Service-Oriented Architecture (SOA) #### 定义与特点 面向服务的架构(Service-Oriented Architecture, SOA)是一种软件设计和开发方法论,旨在通过服务的方式组织和构建应用程序。这种架构的核心目标是实现跨平台、跨语言以及跨组织的无缝集成[^1]。 SOA 的主要特点是: - **标准化接口**:使用开放标准(如 SOAP 和 REST)来定义服务之间的通信协议。 - **松耦合**:服务之间保持较低程度的依赖关系,从而提高灵活性和可维护性。 - **重用性**:服务可以被多个应用重复利用,减少冗余开发工作。 - **互操作性**:不同技术和平台上的组件能够协同工作。 #### 底层工作原理 为了运行和支持 SOA 应用程序,企业通常需要部署一个完整的 SOA 基础设施。该基础设施由一系列工具和技术组成,用于管理和协调各种服务。这些技术包括但不限于以下几种: - **SOAP(Simple Object Access Protocol)**:一种基于 XML 的消息传递协议,允许分布式系统中的对象彼此调用。 - **WSDL(Web Services Description Language)**:描述 Web 服务及其功能的标准格式。 - **UDDI(Universal Description, Discovery and Integration)**:提供了一种机制,使开发者能够在注册表中查找并发布 Web 服务的信息[^3]。 此外,在实际实施过程中,还需要引入 ESB(Enterprise Service Bus),作为中间件负责连接不同的服务端点,并执行路由、转换等功能[^2]。 #### 实际应用场景 ##### 电子商务平台的订单管理系统 在一个典型的电商环境中,订单处理涉及库存查询、支付验证等多个子模块。采用 SOA 架构后,每个独立的功能单元都可以作为一个单独的服务存在。例如,“检查商品库存状态”的逻辑可能对应某个特定的服务实例;当用户提交购买请求时,前端会依次调用相关联的一系列后台服务完成交易过程。 ##### 企业资源规划(ERP)系统 大型企业的 ERP 解决方案往往覆盖财务会计、人力资源管理等领域。借助 SOA 方法学,则可以把原本复杂的整体拆分成若干小型化且高度自治的部分——即所谓的微服务形式呈现出来。这样一来不仅便于后期扩展升级,同时也促进了内部各部门间的数据共享效率提升[^1]。 #### 总结 综上所述可以看出,虽然目前市场上很多产品声称自己具备所谓“支持”性质下的 SOA 特征,但实际上真正做到完全意义上的 “基于 SOA ” 设计却相对较少一些 。真正的 SOA 不仅仅是简单地把现有能力打包成 web service 而已 ,而是要围绕着统一框架体系进行全面重构优化 —— 包括从业务流程自动化到最终用户体验改进等方面均需考虑进去 [^2]. ```python # 示例代码展示如何创建一个简单的 WSDL 文件解析器 from lxml import etree def parse_wsdl(wsdl_file_path): tree = etree.parse(wsdl_file_path) root = tree.getroot() namespaces = { 'wsdl': 'http://schemas.xmlsoap.org/wsdl/' } services = root.findall('wsdl:service', namespaces=namespaces) for service in services: print(f'Service Name: {service.attrib["name"]}') parse_wsdl("example.wsdl") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值