J2EE应用程序部署的一些建议(2)

原创 2004年05月11日 11:14:00

原文来自www.onjava.com

 http://www.onjava.com/pub/a/onjava/2003/06/11/j2ee_deployment.html?page=1

接上一篇

通常认为remote calls比local calls需要花费更多的时间,在远程过程呼叫中,本地代理对象必须copy所有的参数并且把他们通过电缆传送过来,通过RMI,在远程控制对象时,会造成网络交通堵塞和长时间的响应等待


考虑到用户在web page上发出一个命令的细节,而这特殊的请求轮流的调用servlet,随后就是处理在session beans和entity beans中的business method。至少4个网络操作都有同时的运行,其中的2个操作都是remote EJB calls。

当session beanscall 别的 session beans或者多个entity beans时,就需要创建额外的remote calls。如果执行的效果时首先要考虑到的,就需要在构架和设计时作出调整。来减少remote calss 的数量,而且要减少remote calls产生的消耗。

 
这里我们有许多方法来解决perforamce的问题
我们可以通过使用EJB的coarse-grained设计模式来减少网络上的trips
我们可以通过使用本地而不是远程接口或者是实体beans来消除一些不必要的远程呼叫
我们可以通过改变打包结构来使更多的beans部署在一个EAR文件里从而使一些远程呼叫变成本地呼叫

2.1.2 本地接口 VS 远程接口
J2EE1.3中引入本地enterprise beans的概念,它可以允许一个entity beans显示本地接口,这样可以允许以引用reference来传递参数而不是传值value。然而为了使session beans能够访问本地enterprise beans必须将本地enterprise beans打包到和session bean一样相同的EAR文件里。通常有2种方法来实现。
     a.在数据层中可以在entiy beans之前创建一个session Facade,这样可以同样可以使entity beans在内部application中起到同样的作用,然而,如果仅仅依赖这种session Facade技术的话,程序运行的效果可嫩并不是很好。
     b.把entity beans放到business层中,并且允许business层的session beans可以直接连接本地enterprise beans。这样可以减少entity beans重复使用的程度。
自从本地的entity beans只能在位于相同的EAR文件里起作用,在application外部的模块中的其他的business beans就无法来与entity beans连接。而且这将加倍在不同applicatipn 模块中的相同entity beans的实例(instances)

2.1.3打包结构
一些J2EE application server例如BEA的weblogic会优化beasns之间的远程呼叫和本地呼叫.如果beans都在相同的enterprise application中,这很有利于一个session beans呼叫多个session beans或者entity beans.但是这样也有一些不利之处:
   降低可维护性:所有的打包在同一个EAR的beans必须在同一时间被部署或者是重新部署,这样会阻止在运行时间改变beans的可能性.
   平台依赖性:  不是所有的app server都提供这种方式的优化,而且如果你转变app server vendors的话是没有任何作用的.
   可能破坏到设计思路: 许多开发人员设计beans都假设所有的参数通过传值而不是传递引用.如果改变呼叫的约定将会破坏以前的假设,特别是如果传递对象的模式被同时用在entity beans中

2.2 资源定位的考虑:另一个区域我们必须考虑通用资源和库的位置,一条戒律是资源一定要随着用到的J2EE模块在一起.然而,如果在某种情况下比如一些同用资源被几个模块同时用到时,你可以把他放到一个这些模块都可以获取到这些资源的地方.除此之外,把资源路径放入你的系统的CLASSPATH里将会引起与其他J2EE模块部署到相同的容器的冲突.这样会同样的限制你来部署J2EE应用程序

J2EE应用程序部署的一些建议(3)

原文来自 http://www.onjava.com/pub/a/onjava/2003/06/11/j2ee_deployment.html?page=1 接第二篇:2.2.1 R资源绑定(其他类型...
  • leeak
  • leeak
  • 2004年05月12日 18:28
  • 800

J2EE应用程序部署的一些建议(1)

原文地址: http://www.onjava.com/pub/a/onjava/2003/06/11/j2ee_deployment.html?page=11。介绍:如今你和一些资历较高的J2EE开...
  • leeak
  • leeak
  • 2004年05月11日 11:10
  • 822

websphere8 从安装到部署 测试集群应用程序 安装j2ee程序(非常详细)

目录 1. 准备安装文件 2. 安装Installation Manager 3. 为Installation Manager指定安装资源库 4. 创建部署管理器概要文件 5. 创建定制概要...
  • haitaofeiyang
  • haitaofeiyang
  • 2015年10月12日 14:18
  • 2431

IntelliJ 开发j2ee项目设置

idea可以导入eclipse中的web项目,但idea默认的一些设置是和eclipse及MyEclipse是不同的,比如说MyEclipse中的web项目的资源文件夹默认为WebRoot,而idea...
  • tiantiandjava
  • tiantiandjava
  • 2016年04月07日 14:15
  • 3548

J2EE部署建议

 介绍: 如今你和一些资历较高的J2EE开发人员交流的话,他们大部分都很乐意给你提供一些不同类型的EJB的细节问题,或者是怎么样来使用JMS来发送和接受异步的消息。然而很难找到某个人能够描述一个能够确...
  • luedipiaofeng
  • luedipiaofeng
  • 2007年07月16日 23:02
  • 726

J2EE通过tomcat部署的两种方式

本文是介绍J2EE项目,通过tomcat插件方式和eclipse server 视图两种方式的部署。 一、集成Tomcat插件到Eclipse 1. 下载 Tomcat         作者选择...
  • psp0001060
  • psp0001060
  • 2015年10月25日 21:05
  • 5815

Web应用程序设计十个建议

原文链接:  Top 10 Design Tips for Web Apps 原文日期: 2014年04月02日 翻译日期: 2014年04月11日 翻译人员: 铁锚 现代web应用通常在互联...
  • renfufei
  • renfufei
  • 2014年04月11日 15:46
  • 3596

J2EE 中的几种常用模式?及对设计模式的一些看 法

Session Facade Pattern:使用 SessionBean 访问 EntityBean; Message Facade Pattern:实现异步调用; EJB Command Pa...
  • uniquewonderq
  • uniquewonderq
  • 2015年06月09日 20:53
  • 1453

J2EE项目在LINUX环境下的部署:一、LINUX 安装

  一个程序员如果只埋头写代码,而不会部署项目,那我想是一个不合格的程序员。今天有点空余时间,把linux环境下的项目部署,包括数据库的安装,容器的安装,JDK的安装等,会分篇幅做一一阐述的。   R...
  • zjsjava
  • zjsjava
  • 2009年07月10日 13:20
  • 3544

] FPGA设计需注意的方方面面

不管你是一名逻辑设计师、硬件工程师或系统工程师,甚或拥有所有这些头衔,只要你在任何一种高速和多协议的复杂系统中使用了FPGA,你就很可能需要努力解决好器件配置、电源管理、IP集成、信号完整性和其他的一...
  • zhongrg
  • zhongrg
  • 2008年03月17日 20:16
  • 1173
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:J2EE应用程序部署的一些建议(2)
举报原因:
原因补充:

(最多只允许输入30个字)