正在阅读:构建高性能J2EE应用的10个技巧构建高性能J2EE应用的10个技巧

2004-12-27 15:13 出处: 作者:godttj 责任编辑:linjixiong

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

  Java性能的基础----内存管理

  任何Java应用,单机的或J2EE的性能基础都可归结到你的应用是如何管理内存的问题。Java的内存管理包括两个重要任务:内存的分配和内存的回收。在内存的分配中,目标是要减少需要创建的对象。 内存回收是导致性能下降的普遍原因。也就是说,内存中的对象越多,垃圾回收越困难。所以我们对创建对象的态度应该越保守越好。

  在J2EE应用中常见的两个内存有关的问题是:游离的对象(也被称为内存泄露)和对象循环(指大量频繁创建和删除-在Java中体现为解除引用---对象)。

  我们应注意确保所有可到达的对象实际是活的,即这些对象不但在内存中,而且也要在执行的代码中是存在的。当对象在应用中已经没有用了,而我们却忘记了删除对该对象的引用时,游离的对象就出现了。

  我们知道垃圾回收会占用CPU时间。短期对象的大量创建增加了垃圾回收的频率会造成性能下降。

  不要在Servlet中实现业务逻辑

  在构建J2EE应用时,架构工程师通常会使用到J2EE的基本部分,Servlet。

  如果架构师不使用Session Beans, Entity Beans, 或 Message Beans, 那么改进性能的方法就很少。只能采用增加CPU或更多的物理服务器等方法。EJB使用了缓存(cache)和资源池等方法可以提高性能和扩展性。

  尽可能使用本地接口访问EJB

  在早期的J2EE (遵循EJB1.X规范)应用中,访问EJB是`通过RMI使用远程接口实现的。随着EJB2.0的出现,可以通过本地接口访问EJB,不再使用RMI,在同一个JVM中使用远程方法已经少多了。但是现在还是有一些使用EJB1.X实现的应用和不知道使用本地接口的一些EJB新手。为说明这点,我们作个比较:

  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. 没有其他返回步骤!!

热点推荐:
 强!Java实现MSN Messenger聊天 C++程序员容易犯的10个C#错误
 精彩:ASP遗留的二十大积习 软件开发入门学习的个人看法
 Java编程学习:自己DIY一个JSP日历 设计模式的有趣解释-追MM
 网页编程必看:XML文法分析 Windows管理员六大必备下载



察看评论详细内容 我要发表评论
作者笔名简短内容 发表时间
:

键盘也能翻页,试试“← →”键

相关文章

关注我们

最新资讯离线随时看 聊天吐槽赢奖品