提高EJB性能十大技巧

开发 后端
本文叙述为了提高EJB性能,把应用的技巧总结一下一共有十大技巧。

EJB调用是耗时、费力的。怎么提高EJB性能?我们为解决这一问题,开始边写边讨论。等到完成了,我才发现,我们所应用的技巧总结一下,竟有十条。把提高EJB性能的这些技巧总结一下,为以后的项目做参考。

1.用一个Session Bean封装多个Entity Bean,将原来的多个Entity Bean的Remote调用和Local调用封装在一个Session Bean中。所以建立一个ServerFacade,它为多个对象提供统一获取EJB Home和获取对象的接口。ServerFacade为程序要用到的所有EJB的home handle提供缓存,提高访问JNDI Name的时间,达到提高访问效率的目的。以后查找JNDI Name的方法都应写在接口里,调用时直接从接口调用。

2.在EJB的Remote接口中使用粗粒度的方法,不推荐使用细粒度方法。

3.如果EJB的Remote接口获取成功,应不再使用Remote接口,而是将Remote接口构造成一个一般的Java对象,通过调用一般的JAVA 对象的方法来达到减少对网络的访问。

4.如果你部署EJB客户端和EJB在相同的JVM上,建设使用EJB2.0规范的Local接口代替Remote接口。

5.用"transient"关键字声明不必要的数据变量,替代以前的"public"、"private"等,避免不必要的数据变量占用网络资源。示例:

  1. public class DemoCMP implements EntityBean {   
  2. transient EntityContext entCtx;   
  3. transient InitialContext initCtx;   
  4. public String id;   
  5. public String description;   
  6. …   

6.在ejb-jar.XML部署文件中,对Session Bean中非事务的方法,将trans-attribute属性赋为"NotSupported"或"Never"

  1. <ejb-jar>   
  2. …   
  3. <assembly-descriptor>   
  4. <container-transaction>   
  5. <method>   
  6. <ejb-name>abookesessionBean</ejb-name>   
  7. <method-name>*</method-name>   
  8. </method>   
  9. <trans-attribute>NotSupported</trans-attribute>   
  10. </container-transaction>   
  11. </assembly-descriptor>   
  12. </ejb-jar> 

7.设置事务的超时时间,在JBoss中,要修改${jboss.home}/server/${jboss.configuration}/conf /jboss-service.xml ,如下所示:

  1. <server>   
  2. …   
  3. <mbean code="org.jboss.tm.TransactionManagerService"   
  4. name="jboss:service=TransactionManager">   
  5. <attribute name="TransactionTimeout">300</attribute>   
  6. </mbean>   
  7. …   
  8. </server> 

8.当事务锁定数据库的行记录时,事务应跨越可能的最小的时间。

9.调整EJB 服务器的各种参数,如线程数、EJB池大小、连接池参数等。以在JBoss修改连接池参数为示例,进行说明。如果JBoss和MySQL相连,配置${jboss.home}/server/${jboss.configuration}/deploy/mysql-service.xml,来修改连接池参数,包括MinSize、MaxSize、BlockingTimeoutMillis、IdleTimeoutMinutes、 Criteria等,各参数的含义如下所示:
◆MinSize :连接池保持的最小连接数。
◆MaxSize :连接池保持的最大连接数。
◆BlockingTimeoutMillis :抛出异常前最大的等待连接时间。
◆IdleTimeoutMinutes :关闭连接前连接空闲的最大时间。
◆Criteria :有ByContainerAndApplication、ByContainer、ByApplication和ByNothing等值。
下面是一个例子:

  1. <depends optional-attribute-name="ManagedConnectionPool">   
  2. <!--embedded mbean-->   
  3. <mbean code="org.jboss.resource.connectionmanager.JBossManagedConnectionPool"   
  4. name="jboss.jca:service=LocalTxPool,name=MySqlDS">   
  5. <attribute name="MinSize">0</attribute>   
  6. <attribute name="MaxSize">50</attribute>   
  7. <attribute name="BlockingTimeoutMillis">5000</attribute>   
  8. <attribute name="IdleTimeoutMinutes">15</attribute>   
  9. <attribute name="Criteria">ByContainer</attribute>   
  10. </mbean>   
  11. </depends> 

10.对于数据库事务,应选择较低成本的事务等级,避免造成坏数据。递增成本的事务等级包括:
TRANSACTION_READ_UNCOMMITED;
TRANSACTION_READ_COMMITED;
TRANSACTION_REPEATABLE_READ;
TRANSACTION_SERIALIZABLE;

以上是提高EJB性能的技巧,为以后的项目做参考。

【编辑推荐】

  1. 配置JBoss如何从数据库里读取信息
  2. JBoss Rules的入门学习
  3. 在JBoss下通过本地接口访问EJB
  4. JBoss的classLoader问题
  5. 用Eclipse启动JBoss
责任编辑:佚名 来源: 百度博客
相关推荐

2014-10-28 16:11:37

AndroidApp性能优化

2009-06-29 19:13:54

VMware ESX虚拟化虚拟机

2020-07-10 06:10:14

Python开发代码

2011-05-11 10:46:51

2015-03-19 10:24:21

程序员提高职场价值提高职场价值技巧

2009-08-21 17:11:29

VMware Work

2012-10-08 09:21:49

jQuery Mobi

2010-05-07 08:59:50

ASP.NET

2010-08-30 13:54:30

CSS

2017-09-08 10:24:26

云存储平台技巧

2016-11-09 21:33:29

2013-09-26 14:42:28

2014-12-15 14:59:38

2023-02-21 14:55:40

React开发技巧

2011-06-14 18:54:25

网站流量

2009-03-12 09:35:30

求职简历技巧

2016-10-12 09:02:28

大数据存储技巧

2012-10-09 17:31:33

2021-05-12 09:00:00

WebReactJavaScript

2019-05-23 08:08:33

MySQL数据库DBA
点赞
收藏

51CTO技术栈公众号