详细介绍构建高性能J2EE应用的十个技巧

豆豆网   技术应用频道   2007年08月29日  【字号: 收藏本文

内容摘要:构建高性能的J2EE应用不但需要了解常用的实施技巧。下面介绍最常用的10种有效方法,可帮助架构设计师们快速成为这方面的专家。

  1、客户端应用调用本地Stub

  2、该Stub装配参数

  3、该Stub传到skeleton

  4、该skeleton分解参数

  5、该skeleton调用EJB对象

  6、EJB对象执行容器服务

  7、EJB对象调用企业BEAN实例

  8、企业BEA执行操作

  9、执行组装/分解步骤然后返回

  与远程接口处理相比较,本地接口的EJB方法是:

  1、客户端调用本地对象

  2、本地对象执行容器服务

  3、本地对象调用企业Bean实例

  4、企业Bean实例执行操作

  5、没有其他返回步骤!

  如果你不需要从远程的客户端访问一个特殊EJB,就应该使用本地方法。

  在实现Session Bean的服务中封装对实体EJB的访问

  从Servlet访问实体EJB不但效率低而且难于维护。使用Session Facade(会话外观)模式可把对实体EJB的访问封装在会话EJB中,在该会话EJB中通过使用本地接口访问实体EJB而避免过多的远程调用。

  这项技术会有额外的性能和扩展方面的好处,这是因为会话和实体EJB可以使用缓存和资源池技术来进行改进。另外,由于负载的需要,会话和实体EJB可被扩展部署到其他硬件设备上,这比将Servlet层复制扩展到其他硬件设备上要简单的多。

  尽量粗粒度访问远程EJB

  当访问远程EJB时,调用set/get方法将产生过多的网络请求,同时也导致远程接口处理的过载。为避免这种情况,可考虑将数据属性集中在一个对象中,这样通过一次对远程EJB的调用就可以传递所有数据。这项技术就是数据传输对象(Data Transfer Object)模式。

  优化SQL

  J2EE的架构设计工程师和开发人员通常不是SQL专家或经验丰富的数据库管理员。首先应该确保SQL使用了数据库提供的索引支持。在某些情况下,将数据库的索引和数据分开存放会提高性能。但要知道,增加额外的索引可以提高SELECT性能但也会降低INSERT的性能。对于某些数据库,关联表之间的排序会严重影响性能。可以多向数据库管理员咨询。

责编:豆豆技术应用

正在加载评论...