`
myloveiscomealone
  • 浏览: 10452 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

架构高性能J2EE应用程序的十个技巧

阅读更多
构建高性能的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、没有其他返回步骤!

如果你不需要从远程的客户端访问一个特殊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的性能。对于某些数据库,关联表之间的排序会严重影响性能。可以多向数据库管理员咨询。

避免在实体EJB中过多执行SQL

有时候,通过实体EJB访问数据会执行多个SQL语句。根据J2EE 规范,第一步,将调用实体Bean的find(发现)方法;第二步,在第一次调用实体EJB的业务方法时,容器会调用ejbLoad()从数据库中获得信息。

很多CMP(容器管理持久性)在调用发现方法时就缓存了实体数据,所以在调用ejbLoad()时就不再访问数据库了。应该避免使用BMP(Bean管理的持久性)或者自己实现缓存算法避免二次访问数据库。

使用Fast Lane Reader 模式访问只读数据

J2EE 应用经常要以只读方式访问大量长时间不变的数据,而不是访问单个实体,例如浏览在线产品目录。在这种只读情况下,使用实体EJB访问数据会导致严重过载并且实现很麻烦。实体EJB 适合于对单个实体的粗粒度访问,访问大量的列表只读数据时效率不高。不管是使用CMP还是BMP,一定需要编写代码操作多个实体EJB及其关联。这将导致访问多个数据库并存在大量的也是不必要的事务开销。

利用Java Messaging Servce(消息服务)

J2EE规范在JMS中提供了内置的异步处理服务。当涉及到系统需求时,应该了解在什么情况下应该采用JMS进行异步处理的设计。一旦确定要执行一些异步处理,那么同步处理的任务就应该越少越好,将数据库密集的操作安排在稍后的异步处理中完成。

缓存JNDI Lookup查找

很多操作在进行JNDI查找时要消耗大量资源。通常应该缓存JNDI资源避免网络调用和某些处理的过载。可以缓存的JNDI查找包括:

EJB Home Interfaces

Data Sources

JMS Connection Factories

MS Destinations/Topics

一些JNDI包实现了缓存功能。但是调用对EJB主接口的narrow方法时,这种功能作用有限。缓存查找的设计应该使用共享的IntialContext 实例,尽管构建它很麻烦。这是因为需要访问多种数据源,包括应用资源文件JNDI.properties,系统属性的各项参数,传入到构造函数的各项参数。
分享到:
评论

相关推荐

    构建高性能J2EE应用的10个技巧

    ### 构建高性能J2EE应用的10个技巧详解 #### 一、Java性能的基础:内存管理 在探讨如何构建高性能的Java 2 Platform, Enterprise Edition (J2EE) 应用之前,理解Java应用如何高效管理内存至关重要。Java应用的性能...

    J2EE程序的性能优化技巧

    在开发企业级应用程序时,J2EE平台因其强大的功能和组件化特性被广泛采用。然而,随着用户数量的增加,性能优化成为确保系统稳定运行的关键因素。本文将深入探讨J2EE程序性能优化的一些关键技术和策略。 一、概要 ...

    J2EE架构师认证指南

    《J2EE架构师认证指南》是一本针对Java企业级应用开发高级技术的教程,旨在帮助读者掌握J2EE架构设计的核心理念与实践技巧。在深入理解J2EE架构的同时,该指南也会涵盖相关的工具使用,例如在描述中提到的源码分析和...

    Expert One-on-One J2EE Design+and Development

    - **第11章:基础设施与应用程序实现**:从系统架构的角度出发,探讨如何设计和实现一个完整的J2EE应用程序。 - **第12章:Web层的MVC设计**:介绍Model-View-Controller模式在Web层的应用,并提供实现指南。 - **第...

    J2EE性能测试的培训资料

    通过实际案例的学习,可以更深入地理解如何在具体的应用场景下进行性能优化,这些案例通常涵盖了从问题识别到解决方案实施的全过程,对于提升J2EE应用的性能具有极高的参考价值。 综上所述,J2EE性能测试不仅是确保...

    J2EE架构师推荐书目录

    - 实现高性能EJB服务的策略与技巧。 ### 设计模式 - **UML与设计模式**:学习如何运用统一建模语言(UML)来表达软件系统的结构和行为,并掌握常用的设计模式以解决特定问题。 - **重点内容**:UML图示语言的基础...

    J2EE架构师手册.rar

    最后,书中会讨论到J2EE应用的性能优化和故障排查技巧,包括内存管理、线程调度、数据库连接池以及日志和监控工具的使用。这部分内容对于提高应用的稳定性和效率至关重要。 总的来说,《J2EE架构师手册》是一本全面...

    j2ee小综合

    例如,Eclipse有插件支持如JUnit进行单元测试,Maven或Gradle用于构建管理,以及Tomcat、GlassFish等应用服务器的集成,便于运行和调试J2EE应用程序。 此外,压缩包中的"it84"文件可能包含了一些示例项目、源代码、...

    J2EE Architecting and Designing

    在设计高性能J2EE应用时,可以考虑以下几点: - **缓存策略**:合理使用缓存机制,如Ehcache、OSCache等,以减轻数据库负担并提高响应速度。 - **连接池管理**:使用连接池技术来管理数据库连接,避免频繁创建和销毁...

    Expert One-on-One J2EE Design and Development

    - John Carnell(Centare Group的首席架构师)高度评价了本书:“Rod Johnson出色地涵盖了成功构建J2EE应用程序的设计和技术方面。他关于J2EE应用程序设计、开发和部署的直截了当、没有废话的方法使这本书在我的书架...

    J2EE+WEB+架构+研究文集知识及案例

    再者,《J2EE+架构师手册.chm》可能是为高级开发者和架构师准备的,它可能涵盖了J2EE应用的高级架构设计,如分层架构、MVC模式、微服务架构,以及如何在大型项目中进行模块化和解耦。书中可能还会讨论到性能优化、...

    Practical J2EE Application Architecture

    《实用J2EE应用架构》是一本专注于Java企业级应用架构设计与实现的专业书籍,它为开发者提供了构建高效、可扩展且易于维护的J2EE应用程序的深入指导。该书结合理论与实践,旨在帮助读者理解和掌握J2EE平台的核心技术...

    Sun Certified Enterprise Architect for J2EE Study Guide

    9. **性能优化和安全性**:书内还会讨论J2EE应用的性能调优技巧,包括内存管理、线程池和数据库连接池。此外,安全性的主题,如角色基于访问控制(RBAC)、SSL/TLS加密和数字证书也会有所涉及。 10. **实战案例和...

    J2EE完全参考手册-J2EE部署-pdf

    12. **集群和负载均衡**:在大型J2EE应用中,通过集群实现高可用性和性能优化,负载均衡技术则能有效分配服务器间的请求压力。 13. **热部署**:应用服务器通常支持热部署功能,允许在不中断服务的情况下更新和部署...

    Expert One-on-One J2EE Design and Development.pdf

    - **J2EE 1.3兼容的应用服务器**:例如JBoss 3.0.0,用于部署和运行J2EE应用程序。 - **关系数据库管理系统(RDBMS)**:本书使用的是Oracle 8.1.7,用于存储和管理数据。 - **Apache Log4j 1.2**:一个流行的...

    j2ee课程PPT和详细解说

    Java 2 Platform, Enterprise Edition(J2EE)是Oracle公司推出的用于构建企业级分布式应用程序的平台,它提供了丰富的服务和组件模型,以支持各种互联网应用的开发、部署和管理。本课程围绕J2EE展开,旨在帮助学习...

    Expert+One-on-One+J2EE+Design+and+Development.pdf

    13. **性能测试与调优**:讨论了如何对J2EE应用程序进行性能测试,并对其进行优化以提高响应速度。 - **性能指标**:定义了衡量性能的关键指标。 - **调优策略**:提出了一系列提高性能的策略。 14. **结论:...

Global site tag (gtag.js) - Google Analytics