ImageVerifierCode 换一换
格式:DOCX , 页数:20 ,大小:22.98KB ,
资源ID:24261486      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/24261486.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Apache Tuscany SCA 用户指南.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Apache Tuscany SCA 用户指南.docx

1、Apache Tuscany SCA 用户指南介绍这篇用户指南帮助你熟悉SCA概念,并且带你浏览示范怎样创建SCA应用的一个例子。它也说明了Tuscany支持的多种不同环境(例如命令行客户端或Web应用)以及如何打包程序以运行在这行环境中。本说明或许不需要,因为创建一个SCA应用很简单。Tuscany和SCA的主要目的之一是,避免强加的规则和要求,以制约如何去编写应用。我们想让程序员在开发应用的时候,不用担心将要被使用的环境。基本上,你是为了兴趣而写代码,Tuscany提供环境让它运行。因此,本指南只是一个例子,说明怎样开发SCA应用,而不是一个规则。SCA快速指南SCA快速指南给你做SCA概

2、念的概述,并且为下面的例子给你打好基础。如果你已经熟悉SCA,请略过次章。例子概要我们将使用这个计算示例如何开发一个SCA应用。顾名思义,这个例子是实现典型的计算操作。典型操作就是给两个数字被要求对这两个数字进行一些操作,我们的计算程序将能处理加减乘除四则运算。我们开始于一个简单的计算程序并会逐渐的扩展一些高级SCA特性。对于SCA的更多细节,请参考相关规范,打开SCA网站。准备下载Tuscany Java SCA release下载必要的:Java 5Maven 2.0.4+或者Ant 1.7.0运行示例Calculator程序随着SCA二进制包一起分发,在我们开始编写它之前先运行一下示例,

3、很简单!到./samples/calculator目录ant run如果你打算直接使用命令行来执行例程,那么使用以下的命令java -cp .lib uscany-sca-manifest.jar;targetsample-calculator.jar calculator.CalculatorClient一切正常的话,你将会得到以下结果:3 + 2=5.03 - 2=1.03 * 2=6.03 / 2=1.5如果你使用的是源代码分发包的话,我们建议你使用Maven构建并运行这个计算器实例,因为tuscany-sca-manifest.jar是不随源代码分发包一起提供的,它是包含在二进制分发包

4、内,它包含了全部的tuscany的jar包,这样可以让运行实例的命令行漂亮且比较短。构建Calculator实例你将学到的这个例子说明,当你集中于业务逻辑的时候,如何定义你的程序。本教程会带你通过一系列步骤构建一个叫做calculator的集成构建应用,在这个集成应用中所有组件间的连接器都是本地的,使用java定义的接口。实例通览步骤1:定义所需要的功能块:考虑下你的应用如何被分解为一个个较小的功能/服务,每个块都是一个可以在总的应用里使用的逻辑操作单元,这样的话,Calculator应用可以被分为五个功能块:AddService(加)、SubstractService(减)、Multiply

5、Service(乘)、DivideService(除)和一个主功能块,起接收请求并引导到正确操作的控制器的作用。我们可以叫这个控制器为CalculatorService。步骤2:实现每个功能块:既然你已经识别了应用中的功能块,现在将准备创建它们。在SCA里,功能性的块称为组件,那么让我们看看如何去实现一个组件。我们将把AddService组件作为我们的第一个例子。AddService组件将提供两数相加的服务。每当执行相加操作的时候,CalcualtorService组件就会使用AddService组件。如果我们使用java来编写AddService组件的话,我们从描述一个(Java)接口开始。

6、public interface AddService double add(double n1, double n2);现在,我们提供这个接口的实现。public class AddServiceImpl implements AddService public double add(double n1, double n2) return n1 + n2;等等!我们不是在写一个SCA组件么?那一定是很复杂的,仅仅只有Java接口和实现,这是对的么?嗯,实际上一个SCA组件可以是一个普通的Java,因此我们已经做完了实现这个SCA AddService组件所需要的编码。我们能使用SCA暴露A

7、ddService组件在任何支持的绑定上提供服务,例如,WebServices,JMS或者RMI,不需要更改AddService的实现。让我们看一下CalculatorService组件,这很有趣因为它会调用AddService组件,在完整应用中,它会调用SubtractService、MultiplyService以及DivideService组件,但我们目前会忽略其他的,因为它们和我们实现的AddService是一个模式。我们将再次从定义一个接口开始,因为CalcultorService是一个自身提供给其他程序调用的接口。public interface CalculatorService

8、 double add(double n1, double n2);double subtract(double n1, double n2);double multiply(double n1, double n2);double divide(double n1, double n2);现在,我们实现这个接口。public class CalculatorServiceImpl implements CalculatorService private AddService addService;private SubtractService subtractService;private

9、MultiplyService multiplyService;private DivideService divideService;Referencepublic void setAddService(AddService addService) this.addService = addService;.set methods for the other attributes would go herepublic double add(double n1, double n2) return addService.add(n1, n2);.implementations of the

10、other methods would go here步骤3:组装应用:那么,我们该如何让这两个组件运行呢?我们当中的Java程序员说了,写一个main函数,然后就可以将两个组件联系到一起然后运行,这样做很简单。public class CalculatorClient public static void main(String args) throws Exception CalculatorServiceImpl calculatorService = new CalculatorServiceImpl();AddServiceaddService= new AddServiceImpl

11、();calculatorService.setAddService(addService);System.out.println(3 + 2= + calculatorService.add(3, 2);/ calls to other methods go here if we have implemented SubtractService, MultiplyService, DivideService但这样做,没有使用Tuscany SCA运行时,也没有将代码延展至提供Webservice接口,那样的话,会稍微复杂些。那么,我们怎样做可以让它运行在Tuscany内,可以得到很多像自由提

12、供Webservice那样的特性?首先,在我们调用这些组件前,先改变客户端以启动Tuscany SCA运行时。public class CalculatorClient public static void main(String args) throws Exception SCADomain scaDomain = SCADomain.newInstance(Cposite);CalculatorService calculatorService = scaDomain.getService(CalculatorService.class, CalculatorServiceCompone

13、nt);System.out.println(3 + 2= + calculatorService.add(3, 2);/ calls to other methods go here if we have implemented SubtractService, MultiplyService, DivideServicescaDomain.close();你可以看到我们从使用静态方法创建一个SCADomain自身实例开始。SCADomain是一个SCA概念,表示一个SCA系统的边界。它可以跨很多处理器部署,现在,让我们先关注它与在单Java虚拟机内运行。参数Cposite指的是告诉SCA这

14、些组件在我们计算器应用内如何集成工作的一个XML文件。这里是Cposite内的XML。可以看到我们在这里定义了两个组件并且指定了Tuscany SCA需要加载去实现业务计算的Java实现类。它们是我们刚刚实现的那些类。需要注意的是,CalculatorServiceComponent拥有一个对addService的引用,在这个XML配置文件里,这个引用目标是AddServiceComponent。当我们实现CalculatorServiceImpl时,引用名字addService,与我们建立的addService领域的名字相配,这不是巧合。Tuscany SCA运行时从Xml配置文件解析这些信

15、息,并且用来创建描述我们calculator应用程序的对象和关系。它首先创建了AddServiceImpl和CalcualtorSreviceImpl的实例,然后将AddServiceImpl引用注入到CalculatorServiceImpl对象的addService字段域。如果你回过头来看下我们如何实现的CalculatorService,你会发现Reference注释,它告诉SCA哪些字段/域需要被自动设置。这相当于来自我们正常的Java客户端代码。CalculatorServiceImpl calculatorService = new CalculatorServiceImpl();

16、AddServiceaddService= new AddServiceImpl();calculatorService.setAddService(addService);一旦配置文件被SCADomain加载,我们的客户端代码就会要求SCADomain提供CalculatorServiceComponent组件的对象实例引用。CalculatorService calculatorService = scaDomain.getService(CalculatorService.class, CalculatorServiceComponent);我们现在使用这个引用就好像是我们自己创建的一样

17、,例如,来自于CalculatorServiceImpl.add()方法实现:return addService.add(n1, n2);SCA规范往往使用图解的形式描述SCA应用,这往往有利于快速的概览有说明组件组成了该应用以及如何将它们联系在一起,如果我们画一张我们刚刚创建的calculator例子的图,我们会得到如下类似的图:你会发现这些图随我们所有的示例提供。如果你喜欢使用一种可视化的角度去看图的话,这就帮助你快速理解各个例子中的组件。可以看一下每个例子的顶级目录的那些.png文件。步骤4:部署应用:只要Cposite文件和其他的tuscany jar包一起,存在于classpath内

18、,我们就可以像之前做的那样运行我们的例子。这些例子包含一个Ant部署文件build.xml,所以,如果你想测试例子代码的话,你可以如此做并重编译它。ant compile重新编译以后,你可以像在“运行示例”章节那样运行它,我们还在Ant的build.xml脚本里面提供了一个run target以供运行,你可以这样:ant run在calculator内使用更多高级特性回顾以下,我们编写的启动calculator应用的代码,使用的Tuscany SCA运行时不比使用普通java代码更长,然而,我们现在确实有一个XML集成配置文件,描述我们的应用如何被组装。但我们的应用变得更复杂,并且我们想要改变

19、它,重用它,和其他应用集成或者使用一个和我们其他SCA应用一致的编程模型进一步开发它的时候,集成的概念就是一个很大的优势。而不管它们是用说明语言实现的。举个例子,我们认为我们的计算器示例足够强大和易用,我们打算将它放在公司内部网,以供其他人使用他们基于Web2.0的程序,通过浏览器进行直接访问,这个时候我们通常会找书本以努力寻找实现它的办法,因为我们有一个描述我们应用的XML文件,这在Tuscany很容易。如下内容应该达到目的。我们所做的就是增加元素,告诉Tuscany SCA如何暴露CalculatorServiceComponent作为一个JSONRPC服务。注意,我们不需要更改我们组件的

20、Java代码。这只是配置上的一个改变。helloworld-jsonrpc示例展示了一个jsonrpc绑定的工作例子。如果我们需要一个基于SOAP/HTTP的WebService也很容易,helloworld-ws-service和helloworld-ws-reference两个例子展示了如何使用Webservice。SCA允许其他方式的灵活性。我们可以重新连接我们的组件,例如,使用其中一个远超绑定,比如RMI,我们可以让运行在一台机器上的CalculatorServiceCompone连接到另一台机器上运行的远端版本应用,calculator-rmi-service和calculator-

21、rmi-reference展示了如何使用RMI绑定的方法。我们也能引进用不同的语言实现的组件,例如,让我们增加Ruby实现的SubtractServiceComponent组件。当然,我们需要Ruby代码去实现它:def subtract(n1, n2)return n1 - n2endTuscany SCA运行时处理了Java组件连接到Ruby组件的问题,并且进行了必要的数据转换,calculator-script示例展示了不同语言的使用。那么,既然我们的应用程序已经作为SCA装配,那么将来当我们进一步开发它的时候就存在许多的可能性,并且和其他应用集成,接下来的章节会提供更多Tuscany

22、SCA的细节。创建一个在线商店(OnLineStore)SCA集成应用既然你已经熟悉了SCA的概念,你可以利用本教程去创建一个OnLineStore集成SCA应用,给购物车提供Web接口。这个练习会花费少于半小时的时间,它使你熟悉创建一个真正的SCA集成应用的步骤。虽然这里使用了Eclipse作为IDE,但并不要求你具备Eclipse的相关知识。你可以很容易看到在你习惯的IDE里具有相似的步骤。Tuscany SCA域的实现你可能已经从以前例子的通览看到,SCA概述也有提到,SCA有个概念叫做Domain(域)。SCA集成规范的第10部分把SCA Domain描述为“SCA机制的视界”。SCA线路可用来在单个SCA Domain里把组件连接起来。通过以前那个计算器例子可以看到,在组件引用和服务之间的连线,是通过添加一个目标组件名到一个引用,在一个SCA Domain里处理的。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1