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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

本文(外文翻译--J2EE体系结构.doc)为本站会员(聆听****声音)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

外文翻译--J2EE体系结构.doc

1、 浙江工业大学之江学院毕业设计(论文)外文翻译毕业设计(论文)题目:基于J2EE的企业电子投票系统开发与设计 外文翻译(一)题目: J2EE体系结构 外文翻译(二)题目: J2EE项目的选择与风险 分院(系): 信息工程分院 专 业:计算机科学与技术 班 级: 0402 姓 名: 学 号: 200420100219 指导教师: 毕业设计(论文)外文翻译要求1、毕业设计(论文)外文翻译应有两篇,总字符数不少于20000,其文献来源应由指导教师选定后以纸质(复印或打印件)形式随同毕业设计(论文)任务书一并发给学生。复印或打印件上应有指导教师和专业教研室主任的签名和日期。要求每位学生的外文翻译内容不

2、重复。2、翻译的外文文献应主要选自学术期刊、学术会议的文章、有关著作及其他相关材料,应与毕业论文(设计)主题相关,并列入毕业论文(设计)的参考文献;在每篇中文译文首页“页脚”处注明原文作者及出处,中文译文后应附外文原文(指导教师提供的原文,论文上应有指导教师和教研室主任签名)。3、中文译文的基本撰写格式为:题目采用三号黑体字居中打印,正文采用宋体小四号字,行间距一般为固定值20磅,标准字符间距。页边距为左3 cm,右2.5 cm,上下各2.5 cm,页面统一采用A4纸。4、封面上的“外文翻译题目”指中文译文的题目;两篇外文文献,按“封面、译文一、外文原文(一)、译文二、外文原文(二)、外文翻译

3、评阅表”的顺序统一装订。浙江工业大学之江学院毕业设计(论文)外文翻译译文一J2EE体系结构在讨论了J2EE设计中的一些高层次问题之后,现在该来看一看J2EE应用的几个可选体系结构。常见概念首先,让我们来看一看所有J2EE体系结构都共有的几个概念。J2EE应用中的体系结构层下面要讨论的每个体系结构都含有三个主要层,尽管有些体系结构在中间层内因如了另外的划分。经验已经证明了将企业级系统明确地划分成多个层的价值。这确保了责任的明确划分。J2EE的3层体系结构是各类系统中的经验结晶。具有3个或3个以上层的系统已经证明比其内没有中间层的客户-服务器系统具有更大的可缩放和灵活性。 在一个设计完备的多层系统

4、中,每一层应该只依赖于它下面的那一层。例如,对数据库的更改不应该要求对WEB接口的更改。 每一层所特有的东西应该向其他层隐藏起来。例如,WEB应用中的WEB层只应该依赖于服务器小程序API,而中间层只应该依赖于JDBC之类的企业资源API。这两个原则确保了应用修改起来容易,同时修改又不级联到其他层。下面依次来看典型的J2EE体系结构的每一层。企业信息系统(EIS)层这一层有时也叫做综合层(INTEGRATION TIER),由J2EE应用完成其工作所必须访问的企业资源所组成。这些资源包括数据库管理系统(DBMS)和遗留的主机应用。EIS层资源通常是事务性的,EIS位于J2EE服务器的控制之外,

5、尽管该服务器的确以一种标准方式管理事务和连接建池。J2EE设计师对EIS层的设计与部署将是变化的,视该项目的性质(现有服务的绿色场或集成度)而定。如果该项目包含现有服务的集成,EIS层资源可能会影响中间层的实现。J2EE为与EIS层资源的借口提供了强有力的能力,比如访问关系数据库的JDBC API、访问目录服务器的JNDI以及允许连接其他EIS系统的JACA CONNECTOR ARCHITECTURE (JACA连接器体系结构,简称JCA)。J2EE服务器负责建立连往EIS资源的连接池、横跨资源上的事务管理以及保证J2EE应用不危及EIS系统的安全。中间层这一层含有应用的业务对象,并调停对E

6、IS层资源的访问。中间层构件主要从事务管理和连接建池之类的J2EE容器服务中受益。中间层构件独立于选定的用户接口。作者:美亨特美罗夫特斯 来源:精通J2EE(Java企业级应用),2004.7:23-28如果使用了EJB,我们把中间层分离成两层:EJB以及使用这些EJB来支持该接口的对象。但是,这种分离不是保证一个干净中间层所必须的。用户接口(UI)层这一层将中间业务对象暴露给用户。在WEB应用中,UI层由服务器小程序所使用的助手类以及诸如JSP页之类的试图构件所组成。为了清楚起见,我们在讨论WEB应用时将把UI层称做“WEB层”。业务接口的重要性许多人将EJB看做J2EE应用的核心。从J2E

7、E的EJB中心论角度看,会话EJB将暴露应用的业务逻辑,而其他对象(比如Business Delegate J2EE设计模式中的Web层“业务委托”对象)将由他们与EJB的关系来确定。但是,这种假设将一种技术(EJB)抬高到了OO设计考虑之上。EJB不是在J2EE应用中实现中间层的唯一技术。正式业务接口层的概念体现了一不好的习惯,不管是不是使用了EJB,我们都应该使用这个概念。在下面将要讨论的所有体系结构中,业务接后层都有客户(比如UI层)直接使用的中间层接口所组成。业务接口层为普通Java接口中的中间层定义了联系人;因此,EJB就是一个实现策略。如果我们没有使用EJB,业务接口的实现将是运行

8、在J2EE Web容器中的普通Java对象。当使用了EJB时,业务接口的实现将隐藏掉与EJB层的交互。一定要设计到Java接口,而不要设计到具体类,也不要设计到技术。下面来看一下满足不同需求的4种J2EE体系结构。非分布式体系结构下面的这些体系结构适合Web应用。他们可以把所有应用构件只运行在单个JVM中。这使他们变得简单而有效,但限制了部署的灵活性。具有业务构件接口的Web应用在大多数情况下,J2EE用来构造Web应用。因此,同一个J2EE Web容器可以提供许多应用所需要的整个基础结构。和EJB一样,J2EE Web应用实际上享有对企业API的相同访问权。它们受益于J2EE服务器的事务管理

9、和连接池能力,并可以使用JMS,JDBC和Java Connector API之类的企业服务。除实体组件之外的所有数据存取技术都是可以使用的。Web应用的Web层和中间层运行在同一个JVM中。但是,在逻辑上使他们保持不同是极其重要的。Web应用中的主要设计风险是UI构件与业务逻辑构件之间的责任模糊不清。业务接口层将由普通Java类所实现的Java接口来组成。这是一个简单而又可缩放的体系结构,并且能满足大多数应用的需要。长处这种体系结构具有下列优点:l 简单性。这通常是Web应用的最简单结构。但是,如果事务管理或线程化问题要求开发分复杂的代码,使用EJB可能将更简单。l 速度。这样的体系结构遇到

10、了来自J2EE服务器的最小系统开销。l OO设计不会被J2EE构件问题(比如调用EJB的影响)所妨碍。l 容易测试。如果设计合理,无需Web层就能够对业务接口进行测试。l 我们可以发挥服务器的事务支持。l 缩放性很好。如果Web接口是无状态的,则根本不需要来自容器的聚类支持。但是,Web应用可以通过使用服务器支持会话状态复制来分布。弱点应该注意下列这些缺点:l 这种体系结构只支持一个Web接口。例如,它不能支持独立的GUI客户(中间层和这个Web接口在同一个JVM中)。但是,正如我们稍后将回看到的,可以增加一个Web服务层。l 整个应用仅运行在单个JVM中。虽然这提高了性能,但我们无法将构件自

11、由地分配给不同的物理服务器。l 这种体系结构不能使用EJB容器事务支持。我们将需要在应用代码中创建和管理事务。l 服务器没有提供对并发编程的支持。我们必须亲自处理线程化问题,或使用一个解决常见问题的类库,比如util.concurrent。l 将实体组件用于数据存取是不可能的,但可以证明的是,这根本不是什么损失。访问本地EJB的Web应用Servlet2.3规范(SRV9.11)可从在这种体系结构中,Web层与刚讨论过繁荣Web应用体系结构的Web层相同。业务接口也是相同的;这两种体系结构的不同之处从它们的出现(EJB层)开始。因此,中间层被划分成了两部分(运行在Web容器中的业务接口和EJB

12、),但这两部分运行在同一个JVM中。有两种方法可以用来实现业务接口:l 代理方法。在这种方法中,一个本地EJB直接实现业务接口,而Web容器代码被赋予一个对该EJB的本地接口的引用,同时无需处理必不可少的JNDI查找。l 业务委托方法。在这种方法中,业务接口的Web容器实现明确地托付给相应的EJB。这具有允许高速缓存和允许故障操作在适当地点被重试的优点。我们无需担心上述任一情况中的java.rmi.RemoteException捕获。传输错误不会出现。在这种体系结构中,和通过EJB来暴露一个远程接口的体系结构不同,EJB的使用仅仅是这种体系结构的一个实现选择而已,而不是一个基本特征。不用改变总

13、体设计,也不用EJB,就可以实现任何一个业务接口。长处这种体系结构具有如下这些优点:l 它没有分布式EJB应用那么复杂。l EJB使用不更改应用的基本设计。在这种体系结构中,只使这样一些对象成为EJB:它们需要一个EJB容器的那些服务。l EJB使用只强加相当小的性能开销,因为没有远程方法调用或串行化。l 它提供EJB容器事务与线程管理的各种好处。l 如果需要,它允许我们使用实体组件。弱点这种体系结构的缺点有如下这些:l 它比纯Web应用更复杂。例如,它遇到EJB部署和类装人复杂性。l 它仍不能支持除一个Web接口之外的客户,除非我们添加一个Web服务层。l 整个应用仍运行在单个JVM中,这意

14、味着所有构件都必须运行在同一台物理服务器上。l 具有本地接口的EJB测试起来很困难。我们需要在J2EE服务器内运行测试案例(比如用服务器小程序)。l 作为使用EJB的结果,仍存在一些调整对象设计的诱惑,即使含有本地接口,EJB调用仍慢于普通的方法调用,而且这可能会诱惑我们修改业务对象的自然粒度。有时,我们可能会决定把EJB引进到一个没有适应它的体系结构中。这可能是由“做可能管用的最简单事情”的XP方法所造成的。例如,最初的需求可能没有证明由EJB引入的复杂性是值得的,但后来增加的需求可能会提出使用EJB。如果采用上面描述的业务构件接口方法,引进具有本地接口的EJB将不会引起问题。可以简单地选择

15、应该被实现成具有本地的代理EJB的那些业务构件接口。引进具有远程接口的EJB可能有较大疑问,因为这不仅仅是一个引进EJB的问题,而且也是一个从根本上改变了应用的性质的问题。例如,可能需要使业务接口粒度变的更粗,以避免“罗嗦的”调用和实现足够的性能。我们还可能需要把所有业务逻辑实现转移到EJB容器内部。分布式体系结构 下面这两种体系结构除了支持Web应用之外,还支持远程客户。具有远程EJB的分布式应用这种体系结构被广泛地看做“经典的”J2EE体系结构。它提供了这样一种能力:通过给EJB及使用EJB的构件(比如 Web构件)使用不同的JVM来物理和逻辑地划分中间层。这是一个复杂的体系结构,并具有显

16、著的性能开销。虽然描述了一个Web应用,但该体系结构可以支持任一J2EE客户类型。它特别符合独立客户应用的需要。该体系结构在UI层(或者说其他远程客户)与业务对象之间使用RMI,而这些业务对象被暴露为WJB(RMI通信的细节由EJB容器来隐藏,但我们仍需要处理使用它所带来的影响)。这使远程调用变成了一个主要的性能决定要素和一个核心的设计考虑因素。我们必须尽量最大限度的减少远程调用的数量(避免“罗嗦的”调用)。在EJB与EJB客户层之间传递的所有对象都必须是可串行化的,而且我们必须处理更复杂的错误处理需求。该体系结构中的WEB层和上面所讨论的那些结构中的WEB层相同。但是,业务接口的实现将处理对

17、(可能是远程)EJB容器中的EJB的远程访问。在已讨论过的用于本地EJB的两种连通性方法(代理和业务委托)中,只有业务委托在这里是有用的,因为EJB远程接口上的所有方法都抛出JAVAX。RMI。REMOTEEXCEPTION。这是一个已检查异常,否则REMOTEEXCEPTION将需要在UI层代码中被捕获。这把它不正确地束缚到了一个EJB实现上。EJB层将单独负责与EIS层资源的通信,而且应该含有应用的业务逻辑。长处这种通信结构具有如下这些特有的优点l 它可以通过提供一个共享的中间层来支持所有J2EE客户类型l 它允许应用构件在不同物理服务器上的分布。如果EJB层是无状态,这个特点特别管用,进

18、而允许使用无状态的会话EJB。含有有状态UI层和无状态中间层的应用将会从这种部署选择中获得最大的好处,而且将会给J2EE应用实现尽可能大的缩放性。弱点这种体系结构的弱点有如下这些:l 这是我们已讨论过的最复杂的方法,如果这种复杂性确定是业务需求的合理要求,很可能会导致整个项目周期内的资源浪费,并为故障提供一个滋生地。l 它影响性能。远程方法调用会比使用引用的本地调用慢数百倍,总体性能方面的影响结果取决与必须的远程调用数量。l 分布式应用的测试和测试变得很困难。l 所有业务构件都必须进行EJB容器中。虽然这为远程客户提供了一个综合性接口,但如果EJB不能用来解决业务需求所引起的每个问题,这是有问

19、题的。例如,如果SIN-GLETON设计模式完全适用,用EJB满意地实现起来将会很困难。l OO设计被RMI的集中使用所严重阻碍。l 异常处理在分布式系统中变得更复杂。我们除了必须考虑应用故障外,还必须兼顾传输故障。当使用这种体系结构,千万不要破坏它。SUN JAVA CENTER的“FAST LANE READER”J2EE模式主张从WEB层中执行只读JDBC访问,以便最小化通过EJB层进行调用的系统开销。这违背了每个层只应该跟直接位于它下面的那些层进行通信的原则,也降低了缝补式体系结构的一个重要优点;部署灵活性。现在,运行WEB层的服务器必须能够访问数据库,而这会使特殊的防火墙规则车工内为

20、必须之物。即使我们使用了远程接口,如果EJB及使用EJB的构件被放在了一起,那么大多数J2EEE服务器仍能优化远程调用并替换按引用的调用。这可以极大地减少使用具有远程接口的EJB所造成的性能影响,但无法消除远程语义所因如的有害影响。这种配置更改了应用的语句。要想让这种配置得到使用,关键是保证EJB支持本地调用(按引用)和远程调用(按值)。否则按引用的调用者可能会修改要传递其他调用者的对象,进而产生严重的后果。不要因为使用了具有远程借口的EJB导致一个应用变成分布式的,除非业务需求明确指出需要一个分布式体系结构。外文原文(一)J2EE ArchitecturesNow that weve dis

21、cussed some of the high-level issues in J2EE design, lets look at some alternative architecture for J2EE applications.Common ConceptsFirst, lets consider some concepts shared by all J2EE architectures.Architectural Tiers in J2EE ApplicationsEach of the architectures discussed below involves three ma

22、jor tiers, although some introduce an additional division within the middle tier.Experience has shown the value of cleanly dividing enterprise systems into multiple tiers. This ensures a clean division of responsibility.The three-tier architecture of J2EE reflects experience in a wide range of enter

23、prise systems. Systems with three or more tiers have proven more scalable and flexible than client server systems, in which there is no middle tier.In a well-designed multi-tier system, each tier should depend only on the tier beneath it. For example, changes to the database should not demand change

24、s to the web interface.Concerns that are unique to each tier should be hidden from other tiers. For example, only the web tier in a web application should depend on the servlet API, while only the middle tier should depend on enterprise resource APIs such as JDBC. These two principles ensure that ap

25、plications are easy to modify without changes cascading into other tiers.Lets look at each tier of a typical J2EE architecture in turn.Enterprise Information System (EIS) TierSometimes called the Integration Tier, this tier consists of the enterprise resources that the J2EE application must access t

26、o do its work. These include Database Management Systems (DBMSs) and legacy mainframe applications. EIS tier resources are usually transactional. The EIS tier is outside the control of the J2EE server, although the server does manage transactions and connection pooling in a standard way.The J2EE arc

27、hitects control over the design and deployment of the EIS tier will vary depending on the nature of the project (green field or integration of existing services). If the project involves the integration of existing services, the EIS tier resources may impact on the implementation of the middle tier.

28、J2EE provides powerful capabilities for interfacing with EIS-tier resources, such as the JDBC API for accessing relational databases, JNDI for accessing directory servers, and the Java Connector Architecture (JCA) allowing connectivity to other EIS systems. A J2EE server is responsible for the pooli

29、ng of connections to EIS resources, transaction management across resources, and ensuring that the J2EE application doesnt compromise the security of the EIS system.Middle TierThis tier contains the applications business objects, and mediates access to EIS tier resources. Middle tier components bene

30、fit most from J2EE container services such as transaction management and connection pooling. Middle-tier components are independent of the chosen user interface. If we use EJB, we split the middle tier into two: EJBs, and objects that use the EJBs to support the interface. However, this split isnt necessary to ensure a clean middle tier.User Interface (UI) TierThis tier exposes the middle-tier business objects to users. In web applications, the UI tier consists of s

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2