SOA是什么

估计很多人都听说过SOA这个词了,但是很多人还是不知道到底什么是SOA。开发人员很容易理解为是一个Web Service,但是这绝对不是SOA,那顶多只能算是SOA的一种实现方法。那么,到底什么是SOA呢?最近正在看SOA Source Book,本篇我将介绍一下SOA到底是什么?如有错误,欢迎指正。

SOA是Service-Oriented Architecture的首字母简称,它是一种支持面向服务的架构样式。从服务、基于服务开发和服务的结果来看,向服务是一种思考方式

服务

  • 是一种有特定结果的可重复业务活动的逻辑表示(例如,检查客户信用度、提供天气预报等)
  • 自包含
  • 可以组合其他服务
  • 对于服务使用者来说是"黑盒"的

SOA架构样式

  • 基于服务的设计,这些服务代表的是组成企业业务流程的业务活动
  • 服务提供上下文描述(业务流程、目标、规则、策略、服务接口和服务组件),使用服务编排来实现服务
  • 对技术设施提出要求,建议采用开放标准,以便更好的实现可交互性和透明性
  • 实现是基于特定环境的,约束和使能都必须在上下文中进行描述
  • 服务描述和实现需要很好的治理
  • 需要进行验证式的测试之后才能决定这个服务是否好的服务

SOA和EA

虽然SOA和企业架构(EA)的开始不一样,但是现在SOA已经成为企业架构的一个组成部分,所以这里也介绍一下企业架构。

  • 企业架构比IT范围大很多
    • 除技术之外的业务操作、财务、人等
    • 它包含除IT之外的技术,例如制造或物流等
  • 组织实现最大化定义的一些改变
  • 对当前操作的基本控制和治理
  • 企业持续改变,带来成本的减少并能提高商业价值

TOGAF是一个业界企业架构框架,如果想更多了解TOGAF,可以参考我写的企业架构框架-TOGAF v0.2.pdf

由于企业架构范围很大,SOA Source Book值关注企业架构的IT组件:

  • 企业IT的战略性开发
  • 一个完整的企业系统,而不只是一部分系统
  • 长期的IT演进,而不只是满足于短期目标

SOA

  • SOA并不会增大IT系统的内容,但是会提高它们的可交互性
  • IT系统执行一些被明确定义和描述业务活动上下文的服务
  • 之前的应用是那种大的、一整块的应用,只有很小的可交互接口,比较勉强的做集成,对交互也不提供保证。而SOA提供一些小的、模块化的服务,这些服务接口被清晰描述和约定。

Overview of SOA

SOA架构维度

  • 成功应用SOA需要具备丰富的知识和技能
  • SOA不能解决所有IT问题,IT架构师必须知道什么时候以及如何使用SOA
  • SOA将是一个大的投资,是从企业长期战略来考虑的
  • 有时候,技术可能会改变战略,但是业务需要和可能性仍旧是主要驱动力。这也是引入企业架构的原因,企业架构会依据企业的长期战略来设计IT战略。

SOA和无边界信息流(Boundaryless Information Flow)

  • The Open Group的愿景是Boundaryless Information Flow.

  • 因为SOA可以带来无边界信息流,所以SOA在The Open Group占据了重要地位
  • 使用服务来替代应用

SOA给企业带来敏捷

有三个不同的方法来实现企业敏捷性

  • 服务组合
  • 模型驱动开发
  • 服务虚拟化

架构师能够把这些方法都应用到SOA上,但是它们需要不同的基础设施的支持,你必须根据需求来选择合适的方案。

SOA功能和作用

功能

作用

基础设施

Service

  • 改善的信息流
  • 对外公布的能力
  • 功能组织的灵活性
 

Service Re-use

  • 低的软件开发和管理费用

Service repository

Messaging

  • 配置灵活性

Messaging program

Message Monitoring

  • 商业智能Business intelligence
  • 绩效度量
  • 安全攻击检测

Activity monitor

Message Control

  • 应用管理策略
  • 应用安全策略

PDPs and PEPs

Message Transformation

  • 数据转换

Data translator

Message Security

  • 数据机密和集成

Encryption engine

Complex Event Processing

  • 简化软件结构
  • 快速适配外部不同环境的能力
  • 提高可管理性和安全性

Event processor

Service Composition

  • 快速开发新的功能组合

Composition engine

Service Discovery

  • 优化绩效、功能和成本的能力
  • 更容易的系统升级

Service registry

Asset Wrapping

  • 集成现有资产的能力
 

Virtualization

  • 提高可靠性
  • 可以扩充满足不同要求级别
 

Model-driven Implementation

  • 快速开发新功能

Model-implementation

environment

 

      转载自周金根 [ http://zhoujg.cnblogs.com/ ]

SOA框架的更多相关文章

  1. 支付宝soa框架发展思路(转载)

    大家好,这里是首届QCon Beijing的现场,现在坐在我的旁边是的支付宝的首席架构师程立.先给大家介绍一下,支付宝架构发展到今天,经历哪些时期,都有哪些里程碑? 我回忆一下,支付宝系统架构发展大概 ...

  2. 从零开始设计SOA框架(三):请求参数的加密方式

    第二章中说明请求参数有哪些,主要是公共参数和业务参数,服务端需要对参数进行效验,已验证请求参数的合法性 参数效验前先解释下以下参数: 1.参数键值对:包括公共参数.业务参数      1.公共参数:按 ...

  3. 从零开始设计SOA框架(二):请求/响应参数的设计

    每个接口都有请求参数.响应参数.其中请求参数分为公共参数和业务参数.响应参数分为两类:正常的响应参数.统一的错误参数   一.请求参数 1.公共参数:每个接口都有的参数,主要包含appkey.时间戳. ...

  4. Ant.SOA微服务框架开源

    开源地址:https://github.com/yuzd/AntServiceStack   框架特色0.Service Management(服务治理) 1.CodeGen Contract Fir ...

  5. 浅谈SOA

    概念 wiki对于SOA定义如下: A service-oriented architecture (SOA) is a design pattern in which application com ...

  6. SOA、ESB、NServiceBus、云计算 总结

    SOA SOA 是通过功能组件化.服务化,来实现系统集成.解决信息孤岛,这是其主要目标.而更进一步则是实现更快响应业务的变化.更快推出新的应用系统.与此同时,SOA 还实现了整合资源,资源复用. SO ...

  7. WCF SOA --- AJAX 跨域请求处理 CORS for WCF

    一.问题        跨域请求无法处理的问题,由于为了阻止恶意的网站通过JS脚本来窃取正常网站受保护的资源.所由所有的浏览器的默认策略是阻止XmlHttpRequest的跨域的异步请求. 但是对于一 ...

  8. SOA、ESB、NServiceBus、云计算

    SOA.ESB.NServiceBus.云计算 总结 SOA SOA 是通过功能组件化.服务化,来实现系统集成.解决信息孤岛,这是其主要目标.而更进一步则是实现更快响应业务的变化.更快推出新的应用系统 ...

  9. webService-cxf框架的使用

    webService-cxf框架的使用: 1:简介: wbservice常用框架 Axis: --> Axis2 XFire: -->(Web Service框架) XFire是codeH ...

随机推荐

  1. TP5隐藏url中的index.php

    在public文件夹下,有个.htacess文件,没有则新建一个, 如果已有这个文件,原文件内容如下: <IfModule mod_rewrite.c> Options +FollowSy ...

  2. linux日常管理-sar工具

    查看网卡瓶颈 查看网卡流量 默认10分钟一次 查看实时流量  每秒钟显示一次 显示5次 网卡有 lo eth0   主要看eth0外网  rxbyt/s 进网口和 txbyt/s出网口 带宽看txby ...

  3. foregroundservice的用处和用法

    由于android的系统资源回收机制,当内存不足的时候,会自动关闭一些后台服务,如果这时候我们的服务正在播放歌曲,由于被关闭,歌曲会被中断,这样会造成很差的用户体验. 这时候我们可以通过在servic ...

  4. Entity Framework Code-First(13):Configure Many-to-Many

    Configure Many-to-Many relationship: Here, we will learn how to configure Many-to-Many relationship ...

  5. 会话临时表 ORA-14452

    需要使用Oracle的临时表,向其中插入记录,用完后再删除.但是后来发现临时表的删除总是失败,返回错误: ORA-14452: attempt to create, alter or drop an ...

  6. 多个VSTO解决方案间传输变量

    参照微软官方文档,为需要公开参数的解决方案添加公开接口.不过稍显遗憾的是,不能传输List泛型 https://docs.microsoft.com/zh-cn/visualstudio/vsto/c ...

  7. 2017BAPC初赛A(思维,无序图,向量)

    #include<bits/stdc++.h>using namespace std;string goods,sister[100010];int x,m;unordered_map&l ...

  8. Unity3D -- shader语法内置函数

    该篇是Unity Shader中HLSL的内置函数,主要是一些数学方面的计算函数.在写Shader的时候可以直接使用. abs //计算输入值的绝对值. acos //返回输入值反余弦值. all / ...

  9. SpringBoot2.0 基础案例(04):定时任务和异步任务的使用方式

    一.定时任务 1.基本概念 按照指定时间执行的程序. 2.使用场景 数据分析 数据清理 系统服务监控 二.同步和异步 1.基本概念 同步调用 程序按照代码顺序依次执行,每一行程序都必须等待上一行程序执 ...

  10. SSM框架的集成

    一 : SpringMVC 接收参数 基本数据类型+String JavaBean 一对一 一对多 Map List 注解 @RequestMapping("/user/add") ...