项目进行到这里,开始出现新的问题。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"等,避免不必要的数据变量占用网络资源。示例:
public class democmp implements entitybean {
transient entitycontext entctx;
transient initialcontext initctx;
public string id;
public string description;
…
}
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修改连接池参数为示例,进行说明。如果jboss和mysql相连,配置${jboss.home}/server/${jboss.configuration}/deploy/mysql-service.xml,来修改连接池参数,包括minsize、maxsize、blockingtimeoutmillis、idletimeoutminutes、criteria等,各参数的含义如下所示:
i.minsize :连接池保持的最小连接数。
ii. maxsize :连接池保持的最大连接数。
iii. blockingtimeoutmillis :抛出异常前最大的等待连接时间。
iv. idletimeoutminutes :关闭连接前连接空闲的最大时间。
v. criteria :有bycontainerandapplication、bycontainer、byapplication和bynothing等值。
下面是一个例子:
10.对于数据库事务,应选择较低成本的事务等级,避免造成坏数据。递增成本的事务等级包括:
transaction_read_uncommited,
transaction_read_commited,
transaction_repeatable_read,
transaction_serializable
闽公网安备 35060202000074号