设为首页收藏本站language→→ 语言切换

鸿鹄论坛

 找回密码
 论坛注册

QQ登录

先注册再绑定QQ

查看: 1763|回复: 0
收起左侧

提高EJB性能的十大技巧

[复制链接]
发表于 2012-5-8 11:02:35 | 显示全部楼层 |阅读模式
提高EJB性能的十大技巧
EJB调用是耗时、费力的。怎么提高EJB的性能?我们为解决这一问题,开始边写边讨论。等到完成了,我才发现,我们所应用的技巧总结一下,竟有十条。把提高EJB性能的这些技巧总结一下,为以后的项目做参考。
1.用一个Session Bean封装多个Entity Bean,将原来的多个Entity BeanRemote调用和Local调用封装在一个Session Bean中。所以建立一个ServerFacade,它为多个对象提供统一获取EJB Home和获取对象的接口。ServerFacade为程序要用到的所有EJBhome handle提供缓存,提高访问JNDI Name的时间,达到提高访问效率的目的。以后查找JNDI Name的方法都应写在接口里,调用时直接从接口调用。
2.EJBRemote接口中使用粗粒度的方法,不推荐使用细粒度方法。
3.如果EJBRemote接口获取成功,应不再使用Remote接口,而是将Remote接口构造成一个一般的Java对象,通过调用一般的JAVA对象的方法来达到减少对网络的访问。
4.如果你部署EJB客户端和EJB在相同的JVM上,建设使用EJB2.0规范的Local接口代替Remote接口。
5."transient"关键字声明不必要的数据变量,替代以前的"public""private"等,避免不必要的数据变量占用网络资源。
6.ejb-jar.XML部署文件中,对Session Bean中非事务的方法,将trans-attribute属性赋为"NotSupported""Never"
7.设置事务的超时时间,在JBoss中,要修改${jboss.home}/server/${jboss.configuration}/conf/jboss-service.xml
8.当事务锁定数据库的行记录时,事务应跨越可能的最小的时间。
9.调整EJB 服务器的各种参数,如线程数、EJB池大小、连接池参数等。以在JBoss修改连接池参数为示例,进行说明。如果JBossMySQL相连,配置${jboss.home}/server/${jboss.configuration}/deploy/mysql-service.xml,来修改连接池参数,包括MinSizeMaxSizeBlockingTimeoutMillisIdleTimeoutMinutesCriteria等,各参数的含义如下所示:
1)MinSize :连接池保持的最小连接数。
2)MaxSize :连接池保持的最大连接数。
3)BlockingTimeoutMillis :抛出异常前最大的等待连接时间。
4)IdleTimeoutMinutes :关闭连接前连接空闲的最大时间。
5)Criteria :有ByContainerAndApplicationByContainerByApplicationByNothing等值。
10.对于数据库事务,应选择较低成本的事务等级,避免造成坏数据。递增成本的事务等级包括:
TRANSACTION_READ_UNCOMMITED,
TRANSACTION_READ_COMMITED,
TRANSACTION_REPEATABLE_READ,
TRANSACTION_SERIALIZABLE
您需要登录后才可以回帖 登录 | 论坛注册

本版积分规则

QQ|Archiver|手机版|小黑屋|sitemap|鸿鹄论坛 ( 京ICP备14027439号 )  

GMT+8, 2024-11-25 19:38 , Processed in 0.069190 second(s), 13 queries , Redis On.  

  Powered by Discuz!

  © 2001-2024 HH010.COM

快速回复 返回顶部 返回列表