`
jiangduxi
  • 浏览: 444498 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论
阅读更多
SOA很早以前就听说过,但是不是很熟,最近有时间研究下,给出一些自己的认识和知识的总结。

   SOA:面向服务架构其本质上是一种将系统模型和系统实现相分离。为什么会分离呢?引导分离的因素就是需求(众所周知,在项目中需求的变更无疑是给项目增大了很大的风险)。SOA本身是一个组件模型,它将 应用程序的不同功能单元---服务(service)。通过服务间定义良好的接口和约定联系起来。接口采用中立的方式定义,独立于具体实现服务的硬件平台、操作系统和编程语言,使得构建在这样的系统中的服务可以使用统一和标准的方式进行通信。这种具有中立的接口定义(没有强制绑定到特定的实现上)的特征称为服务之间的松耦合。
SOA不是一种具体的技术,也是一种产品更不是一种语言,它是一种软件系统架构。更确切的说它是一种架构理念。
    SOA中强调的是服务(Service)它的基本元素也是服务。很多时候你可以将设计和实现出来的软件称为服务品。SOA指定一组实体(服务的提供者、服务消费者、服务注册、服务条款、服务代理等)这些实体详细的描述了如何来提供和消费服务。而这些服务是可互操作、独立、模块化、位置明确、松耦合并且可以通过相关途径查找得到。

以下是在一些资料找看到和学习到的SOA的三种角色的关系。
引用

  服务时一个自包含的、无状态的实体,可以由多个组件组成。它通过事先定义的界面响应服务请求。它也可以执行诸如编辑和处理事务等离散任务。服务本身并不依赖其他函数和过程的状态。

  服务提供者(service provider)提供符合约定的服务,并将它们发布到服务代理。

  服务请求者(service consumer)它发现并调用其他的软件服务来提供解决方案。

  服务代理者 (service broker) 产生由服务提供者发布的软件接口。

  这三种 SOA 参与者:服务提供者、服务代理者以及服务请求者通过 3 个基本操作:发布(publish)、查找(find)、绑定(bind)相互作用。服务提供者向服务代理者发布服务。服务请求者通过服务代理者查找所需的服务,并绑定到这些服务上。服务提供者和服务请求者之间可以交互。


所谓服务的无状态,是指服务部依赖任何事先设定的条件,是状态无关的(state-free)。在SOA架构中,一个服务不会依赖于其他服务的状态。它们从客户端接受服务请求。因为服务时无状态的,它们可以被组合、编排、序列化成多个不同序列,来执行逻辑。

SOA的一些特征:
引用

  服务的封装(encapsulation).将服务封装成用于业务流程的可重用组件的应用程序函数。它提供信息或简化业务数据从一个有效的、一致的状态向另一个状态的转变。封装隐藏了复杂性。服务的API保持不变,使得用户远离具体实施上的变更。

服务的重用(reuse)。服务的可重用性设计显着地降低了成本。为了实现可重用性,服务只工作在特定处理过程的上下文(context)中,独立于底层实现和客户需求的变更。


·服务的互操作(interoperability)。互操作并不是一个新概念。在CORBA、DCOM、web service中就已经采用互操作技术了。在SOA中,通过服务之间既定的通信协议进行互操作。主要有同步和异步两种通信机制。SOA提供服务的互操作特性更利于其在多个场合被重用。


·服务是自治的(Autonomous)功能实体。服务是由组件组成的组合模块,是自包含和模块化的。


SOA非常强调架构中提供服务的功能实体的完全独立自主的能力。传统的组件技术,如。NET Remoting, EJB,COM或者CORBA,都需要有一个宿主(Host或者Server)来存放和管理这些功能实体;当这些宿主运行结束时这些组件的寿命也随之结束。这样当宿主本身或者其它功能部分出现问题的时候,在该宿主上运行的其它应用服务就会受到影响。


SOA架构中非常强调实体自我管理和恢复能力。常见的用来进行自我恢复的技术,比如事务处理(Transaction),消息队列 (Message Queue),冗余部署(Redundant Deployment)和集群系统(Cluster)在SOA中都起到至关重要的作用。


·服务之间的松耦合度(Loosly Coupled)。服务请求者到服务提供者的绑定与服务之间应该是松耦合的。这就意味着,服务请求者不知道提供者实现的技术细节,比如程序设计语言、部署平台,等等。服务请求者往往通过消息调用操作,请求消息和响应,而不是通过使用 API 和文件格式。


这个松耦合使会话一端的软件可以在不影响另一端的情况下发生改变,前提是消息模式保持不变。在一个极端的情况下,服务提供者可以将以前基于遗留代码(例如,COBOL)的实现完全用基于 Java 语言的新代码取代,同时又不对服务请求者造成任何影响。这种情况是真实的,只要新代码支持相同的通信协议。


·服务是位置透明的(location transparency)。服务是针对业务需求设计的。需要反应需求的变化,即所谓敏捷(agility)设计。要想真正实现业务与服务的分离。就必须使得服务的设计和部署对用户来说是完全透明的。也就是说,用户完全不必知道响应自己需求的服务的位置,甚至不必知道具体是哪个服务参与了响应。


[b]三个抽象级[/b]
引用

从概念上讲,SOA 中有三个主要的抽象级别:

·操作:代表单个逻辑工作单元(LUW)的事务。执行操作通常会导致读、写或修改一个或多个持久性数据。SOA 操作可以直接与面向对象 (OO) 的方法相比。它们都有特定的结构化接口,并且返回结构化的响应。完全同方法一样,特定操作的执行可能涉及调用附加的操作。

·服务:代表操作的逻辑分组。服务可以分层,以降低耦合度和复杂性。一个服务的粒度(granularity)大小也与系统的性能息息相关。粒度太小,会增加服务间互操作通讯的开销;粒度太大,又会影响服务面对需求变化的敏捷性。


·业务流程:为实现特定业务目标而执行的一组长期运行的动作或活动。业务流程通常包括多个业务调用

在SOA中,业务流程包括依据一组业务规则按照有序序列执行的一系列操作。操作的排序、选择和执行称为服务或流程编排。典型的情况是调用已编排服务来响应业务事件。从建模的观点来看,由此带来的挑战是如何描述设计良好的操作、服务和流程抽象的特征以及如何系统地构造它们。这些涉及服务建模、特征抽取的问题已经成为现阶段人们关注的焦点。




分享到:
评论

相关推荐

    正确认识SOA的架构与规划

    SOA(Service Oriented Architecture, 服务导向架构)无疑是当前信息技术领域中的热门话题,IT行业分析公司Gartner认为SOA将成为创建和交付软件的主导框架,同时预测到2010年 时,应用软件收入增长的80%将来自基于...

    SOA的设计误区(SOA架构师必读)

    如果无法更准确的把握SOA实施对于技术性能的要求,... 如果要防患于未然,就需要看一看关于对普通关键结构误解,这些误解会导致重要文体(最终危及SOA的成功实施)每一个错误认识都是从实时SOA设计的角度来考虑的。

    从架构和规划正确认识SOA

    SOA(Service Oriented Architecture,面向服务的架构)无疑是当前信息技术领域的热门话题。著名咨询机构Gartner称,SOA将成为创建和交付软件的...如果企业是从架构及规划的角度考量SOA,就会对其优势有更深入的认识。

    SOA.rar_SOA_soa best

    SOA最佳实践能提供给你对soa的重新认识

    soa核心技术及应用第三部分

    本书详细的介绍了SCA SDO 和 BPEL,是一本不可多得的好书。 本书是继《SOA·方法·实践》之后,IBM SOA技术专家精心打造的又一SOA技术力作,是SOA专注...使读者在读完本书之后对SOA的核心技术有认识、有想法、有行动。

    中国SOA年度调查报告

    在中国的各行各业中,敏捷的操作、快速的发展和变革促使每个企业的业务高管和IT高管都开始关注中国企业的综合管理能力的提高。SOA在中国帮助国内企业转型,改善信 ...2008年中国软件从业人员对SOA的认识和看法。

    解析在SOA中实现语义互操作性

    本文的目标是使应用程序架构师和数据架构师认识到语义和语义互操作性的重要性,以便在构建新的基于 SOA 的解决方案或者将现有系统迁移到 SOA 时能够进行合理的决策。要想理解语义互操作性,我们首先必须了解其背后的...

    开源SOA(中文完整版)_javasoa_

    认识SOA本质,以及如何使用和开发自己的SOA程序

    SOA相关标准规范简介

    总结当前SOA相关标准规范,给出结构化的认识,并简单介绍

    SOA达人迷.pdf

    以及在Web 2.0、统一通信和云计算环境中认识SOA。 《SOA达人迷》由赫尔维茨、Robin Bloor、Marcia Kaufman、Fern Halper所著,《SOA达人迷》的读者对象是对面向服务架构感兴趣的IT开发人员、分析师与架构师。通过...

    精通 SOA:构建服务组合

    尽管面向服务的体系结构或 SOA 仍然是新生事物,但许多公司正逐步认识到需要采用 SOA 方法作为执行满足业务需求的解决方案的方法。采用这种方法的一个关键步骤是构建可重用服务的组合。SOA 表示新应用程序的设计、...

    SOA引领企业应用踏上随需应变之路

    SOA引领企业应用踏上随需应变之路,由IBM高级工程师编写,全文思路清晰,阐述明确,为认识SOA架构有很大帮助

    理解SOA中的服务生命周期:设计时

    在本文中,通过进一步理解与共享服务生命周期相关的设计时需求,正在寻求使用SOA促进重用和增加业务灵活性的企业可能认识到及早建立基础架构(如方法学、分 类指导方针以及开发工具)是实现早期及后续成功的重要因素...

    关于重置SOA新视点

    但是CIO们也开始认识到SOA并非一个简简单单走过场的项目,Richard Thomas,昆泰跨国公司(Quintiles Transnational,一家制药、医疗保健和生物科技研究公司)的高级副总裁和首席技术官就说,“一个SOA计划的目标决非...

    SOA实施关键:构建服务组合

    目前许多公司正逐步认识到需要采用 SOA 方法作为执行满足业务需求的解决方案的方法。采用这种方法的一个关键步骤是构建可重用服务的组合。而SOA 作为沟通 IT 世界和业务世界的桥梁这一论断在不断地发展着。服务组合...

    SOA探秘——BEA

    这个Flash将给你一个清晰地认识SOA的过程。

    简析分布式SOA基础架构

    目前,关于面向服务的架构,即...然而,糟糕的是,这种做法往往会造成认识上的混乱,甚至让用户对SOA丧失信心。因为厂商往往无法完全兑现他们所做的承诺,销售的所谓适合SOA架构的技术解决方案也许最终证明并不合适。

Global site tag (gtag.js) - Google Analytics