`

三句话讲清楚SOA

    博客分类:
  • SOA
阅读更多

一、问:为什么要SOA答:因为SOA出现前,世界上有Corba组件模型、JAVA组件模型、COM+组件模型、.NET组件模型。其中,CORBA组件模型和JAVA组件模型属于IBM为首那一类阵营(一伙的还有BEA、ORACLE、HP、SUN之类的),而COM+组件模型和.NET组件模型属于微软这独个一家的,自古两个阵营是表面同行、暗地互掐。

IBM当然需要四海一家的解决之道。因为JAVA组件模型老受SUN的牵绊,而且江湖风传EJB已死。CORBA组件模型呢,一直没有当过老大主流流行过。其他两个组件模型都在微软封闭的圈子里,IBM就想在在这四大组件模型之上再加一层组件模型,这样就天下大同了,这就是SCA

有了SCA组件模型,各个异构组件模型现在都被包装成一样的组件了,怎么数据传递?当然就是SDO来帮忙。

二、问:听说SOA主要优势是整合,但是我们既然有webService了,要SOA干吗?答:WebService是整合包装统一成WebService协议族的很好的规范,但WebService又不是组件模型。有人问了,你管我是组件不是组件,我给你包装一层webservice,咱们俩能调用就OK了。

这就涉及到咱们国家的计算机发展阶段了。因为咱们国家的开发界,N多程序员还停留在双击一下按钮,IDE自动给生成一个onclick事件,然后在里面写东西。很多程序员根本没有意识去主动写函数,程序里的函数都是IDE自动生成的事件处理函数,并非程序员写的自己的函数。连函数都没有主动意识的,怎么会有主动意识去自己编写类,自己编写组件类,大多数程序员在使用系统提供的类库,系统提供的可视化组件。所以,N多程序员就不明白为什么要有SOA组件模型了。

世界主流代码开发都已经是编写组件类了,这是业界的发展需求,但我们国内代码开发水平和需求还没有到这个层次,还在onclick。所以我们不理解。

如果我们也平时很自然的自己编写组件类,那么我们现在很自然的希望有支持SOA的组件模型,因为这样的组件模型,就可以很通畅的和过去的CORBA组件模型、JAVA组件模型、COM+组件模型、.NET组件模型交互了。如果我们现在还不用SOA组件模型,还在用四大组件模型,以后想异构组件之间交互,还得再开发一层SCA

三、问:那SOA就这么简单?就是SCA+SDO答:前国际SOA标准推出的就是这两大标准,SCASDO。和SOA关联的还有两个东西,一个是BPEL,一个是ESBSCA是有了统一的组件,SDO是有了统一的组件数据交互,BPEL是让组件之间串联在一起,然后自动运行,就如同我们把一个个的鞭炮拧在一起,然后点燃捻子,鞭炮就全都自己串联着爆炸了,BPEL就是干这个用的。而ESB呢,就如同各个组件,都需要在一个容器中执行,号称组件容器服务器,JBOSS最初的功能就是EJB组件的容器服务器。而ESB呢,当然就是SOA组件的容器服务器了。

四、问:SOA就这么简单吗?我怎么看书看网站,说是让业务人员和技术人员更好的结合,要用业务角度去看技术,这个话不理解?答:这是给SOA组件设计师一个设计指导。也就是说,当你要设计一个SOA组件,你要暴露出什么功能,要多达粒度的,可能你这个组件类可以围绕一个主题完成10个功能,但10个功能编写实现比较复杂,你最后内部写代码的时候写成了函数嵌套函数,那么你内部有许多函数了,你到底要暴露出哪些。咱们设计组件类的接口,往往不容易把握粒度的问题。就如同你如果刚刚一开始写面向对象的代码,很容易会滥用对象,设计的对象很多,如果还没有过面向对象开发的程序员,你可能想像不出来为什么会有这种过度使用对象的现象。人就是这样,用的爽了,就容易过度使用。所以什么粒度合适,给指导了,面向业务。从组件类的消费者角度来看,需要暴露出哪些功能。这就有了一方是功能消费调用者,一方是功能输出产生者,那么这个功能输出,用行话就是输出的是服务。

五、问:SOA就这么简单吗?我看书看网站说,SOA可以使软件灵活,我们现在就是软件代码越来越复杂,功能越来越多,客户需求提出来,我们很难下手修改,修改起来费时间,而且还不知道这块修改了会影响哪块,让软件质量无法稳定,我们正需要SOA,但是SOA是怎么做到这点了,我不理解呀?答:当然COM+、EJB成为风潮的时候,都说过这个话。你想啊,软件都是一个个封装密闭的组件,把组件连接起来,这当然灵活了。你想想你现在,.NET给你提供了许多可视化组件,也提供了许多非可视化组件,人家就是用组件做成了,你现在开发起来,把组件拖拽下来,设置一下属性,编程一下方法,你现在开发速度快多了吧,如果没有这么多组件,你想你多累。这就是组件的好处与灵活性。SOA组件也是组件,只不过是包装的更高一层的组件,是为了让四大组件模型能统一顺畅调用的,所以你把SOA组件当成.net组件来看待就很明白了。

六、问:中国现在好多企业都还没有信息化,即使一些很赚钱的行业或垄断国企做了信息化,但都自己封闭起来,和其他企业之间老死不相往来,SOA在中国有用处吗?答:你用不用SOA组件模型,就如同你用不用.NET组件一样,管整合什么事。你如果只想整合,webservice就可以了。用不用组件式开发,是你自己的事情,如果你想让你的程序变的灵活。你看.net里面那么多组件,给你的开发带来了很多的轻松啊。

七、问:现在SOA成熟吗?该到应用的时候了吗?答:成熟不成熟,你得看支持SOA标准的开发工具成熟没成熟,做SOA应用就需要成熟的开发工具。有了能很顺手的SOA组件开发工具,那就看看有没有成熟的SOA组件容器服务器。如果这两项都不错了,就可以开发了。我们当年开发COM+的时候,COM+不成熟,COM+开发工具不成熟,COM容器不成熟,造成线程死锁、并发排队、缓冲池崩溃、内存泄露很多问题,搞的我们很是头疼,最后找来开发工具厂商的人,找来微软,才算弄清问题,原来一方面是微软COM+有问题,一方面开发工具也有问题,白耽误了我们许多时间。不过福兮祸兮,倒是让我对组件模型、WINDOWS基础核心技术思想倒是精进不少。

八、问:我看你有点误导人。现在企业级开发,实际主流标准就两个,一个是.NET,一个是JAVA。.NET本来就似乎支持WebService第一类的技术,而JAVA是后来才加入WebService的,所以算不得原生结合。况且微软自己自成一套体系,.NET组件模型也很好,我为什么要用SOA组件模型呢?答:确实这里面也有些商业目的。虽然IBM现在是JAVA领域的领头羊,也在JAVA上建立了一整套产品体系,投资颇大,但毕竟JAVA是出自SUN,所以SUN为了保护自己的利益当然要不让IBM自己主导的很爽了,所以JAVA要推出一项特性,往往时间很慢,而且总需要兼顾各方利益,所以大家都看到,近几年出来的JAVA新特性标准都不尽人意,就是各方利益拉锯的产物,谁也不得罪,就形成了中庸的东西。IBM早就想甩开SUN了,但IBM在JAVA上也投资巨大,如果另起炉灶也不太可能,所以想到这个移花接木的方法,把JAVA架空。出了一个SOA模型,各种语言都可以实现,不仅仅限于JAVA平台上,在SOA的统一架构技术至上,就没有JAVA痕迹了,那就轮到IBM大显身手了,所以OSOA组织,SUN是很靠后才参加的。因为SUN知道,不参加会被甩的更远,现在参加,还能捞点残余。反正最终的命运是要被扫走。

SUN的JAVA被IBM正在一步步边缘化,当然投入过深,想抽出来也不容易,但IBM有这个财力也有这个耐心。IBM不断宣称开源,ECLIPSE,IBM支持了很多,让大家在开源世界接纳了IBM,而且IBM近几年一直在推动web2.0,也就是轻巧化的开发。企业级开发,大家一想就头疼,都是大框架大平台很复杂,IBM也知道顾客烦了,现在全世界的IT巨头都在宣称简化IT。呵呵,这些家伙,把东西搞复杂故意建造竞争壁垒的是他们,现在简化IT的还是他们,正反都能卖。

而大家要注意到,OSOA推出了SOA标准后,推出了三种实现,一种是JAVA,一种是C/C++,另一种是什么呢?大家猜一猜。

对,它就是PHP。 

最后一点不太认同,不过之前的内容说的非常好。在网上找到这篇文章,转载过来大家共享。

分享到:
评论

相关推荐

    解读SOA :SOA实践方法论

    解读SOA Interpret SOA SOA越来越被企业接受,很多公司都准备规划SOA。但具体怎么上,没有一套很好的方法论是不行的。资料是IBM在长期的摸索中总结的一套SOMA方法论,由于是内部培训资料,所以比较难得。 内容 ...

    SOA.rar_SOA_SOA 开发

    **SOA(Service-Oriented Architecture,面向服务架构)是一种软件设计模式,它提倡将功能作为独立的服务,这些服务可以通过网络进行交互,实现模块化、松耦合的系统。在本压缩包“SOA.rar”中,我们主要探讨的是...

    SOA资源,SOA教程,SOA开发

    SOA资源,SOA教程,SOA开发SOA资源,SOA教程,SOA开发

    通过Oracle EBS 看SOA

    几年前就经帯在网上看到戒者在一些讲座中听到,但自己真正比较“近距离”接触“SOA”,还是在去年的“中国IT精英年会”上,当时IBM大中华区的老总大谈IBM 的SOA,BEA公司(当时还没被Oracle 收购)也讲了很多SOA的案例,SAP...

    SOA.zip_SOA optical_SOA 光_SOA 半导体_VPI SOA仿真_光放大

    **SOA光学与半导体光放大器** 在信息技术领域,特别是在光纤通信系统中,半导体光放大器(Semiconductor Optical Amplifier,简称SOA)扮演着至关重要的角色。SOA是一种利用半导体材料(如镓铝砷化物,GaAs/AlGaAs...

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

    本书详细的介绍了SCA SDO 和 BPEL,是一本不可多得的好书...之后沿此三个主要技术方向做贴地飞行式以应用为核心的全方位介绍,力求深入、敏捷、贴近实际;使读者在读完本书之后对SOA的核心技术有认识、有想法、有行动。

    面向服务架构(SOA)中南大学SOA原理与技术 00 课程简介(共66页).ppt

    面向服务架构(SOA)中南大学SOA原理与技术 01 SOA技术概述(共74页).ppt 面向服务架构(SOA)中南大学SOA原理与技术 02 Web服务基础(共66页).ppt 面向服务架构(SOA)中南大学SOA原理与技术 03 Web服务实现(共...

    通过一个真实故事理解SOA监管

    SOA监管(SOA Governance)是SOA实施中的一个重要话题,但是很多人都搞不清楚其含义。我采访过很多人,也阅读过一些资料,才基本弄明白。总的感觉是,如果 直白地去讲SOA监管的问题,必然引进大量的新术语,一般...

    SOA principles & practice(SOA课程课件 10章)

    **服务导向架构(Service-Oriented Architecture,简称SOA)是一种设计和构建软件系统的方式,其核心理念是通过松散耦合的服务来实现业务功能。本课件详细介绍了SOA的原理及其实践,共分为10个章节,旨在提供一个...

    浅析:SOA三层体系结构及发展状况

    实践论认为:从实践提升到理论,再由...当前国内要发展SOA主要有三方面工作:方法、工具和环境。方法是工程技术,由基础理论来指导提出的。所以一门科学必需要包括:认知科学(哲理)、工程技术和方法、最后是理论。

    SOA面向服务架构

    #### 三、SOA的发展历程 - **早期阶段**:SOA概念并非新生事物,早在上世纪90年代就已经出现了类似的模型,如通用对象请求代理体系结构(CORBA),它提供了类似SOA的接口描述语言(IDL)来定义服务接口。 - **现代SOA**...

    soa pdf 关于soa的文章

    #### 三、SOMA:一种用于开发服务导向解决方案的方法 **服务导向建模与架构(SOMA)**是由IBM提出的一种用于分析、设计、实现和服务导向架构部署的方法论。SOMA提供了一套完整的生命周期模型,帮助组织有效地规划和...

    SOA作业及要求,soa

    SOA,即Service-Oriented Architecture(面向服务的架构),是一种设计复杂应用系统的方法论,其核心理念是将应用程序的不同功能单元通过通信协议联系起来,这些单元被称为服务。SOA强调的是服务之间的松耦合,使得...

    SOAOperation_soa开发_SOA_teamcenter_TeamcenterSOA_

    标题"SOAOperation_soa开发_SOA_teamcenter_TeamcenterSOA_"暗示我们将深入探讨Teamcenter中的SOA操作,这通常涉及到在Teamcenter环境中开发和利用SOA服务来增强其功能。SOA开发意味着创建、管理和维护这些服务,以...

    IBM soa 培训教材-SOA 治理

    #### 三、如何实施 SOA 治理? 实施 SOA 治理的过程包括以下几个关键步骤: 1. **需求分析**:深入理解业务需求,明确服务的目标和范围。 2. **策略制定**:根据业务需求和组织特点,制定适合的服务治理策略。 3. ...

    SOA从业人员指南 SOA入门资料

    ### 第三章:SOA的实施与最佳实践 1. **服务建模**:在规划阶段,需对业务流程进行建模,识别可重用的服务组件。 2. **服务生命周期管理**:从设计到退役,服务需要一套完整的生命周期管理流程。 3. **服务治理**...

    SOA发展历史介绍SOA的发展

    **SOA(Service-Oriented Architecture,面向服务架构)**是一种软件设计范式,它强调通过独立、可重用的服务来构建系统。自20世纪90年代末被提出以来,SOA经历了漫长的发展历程,逐渐成为现代企业信息化建设的重要...

    SOA实践指南-分布式系统设计的艺术.pdf

     1.5 五页幻灯讲完soa 第2章:soa  2.1 soa定义  2.2 soa驱动因素  2.3 soa概念  2.4 soa要素  2.5 soa不是银弹  2.6 soa不是特定技术  2.7 对比soa与分布式对象  2.8 soa术语  2.9 总结 第3章...

Global site tag (gtag.js) - Google Analytics