二,开发EJB应用
如果开发EJB应用,建议采用JBoss作为开发服务器,因为开发、调试、部署速度快。如果采用其他商用服务器,由于实现机理的不同,其编译的速度很慢。
如果采用Entity Beans技术,则您需要知道这么几点。第一,您目标系统的数据源有多少个操作入口,即是否存在Entity Beans之外的方式来操作数据库。如果有,则需要调节相应< container-name >的< commit-option >提交策略以及< locking-policy >策略。
比如,JBoss 3.2.1采用的< commit-option >方式有4种:A、B、C、D。当然,如果除了Entity Beans访问数据库外,别无它出,采用A是很理智的。如果有,则需要取决于具体的情况使用< commit-option >方式。同时,< commit-option >方式的选择与< locking-policy >策略有关系。
能够采用< read-only >的Entity Beans或Entity Beans Methods,则尽量采用,这样会减少或消除死锁发生的可能性。
尽量采用1:n的关系来操作n方的数据表结构,这样能够提高EJB Container的效率。
其中,本文重点给出EJB事务处理方面的探讨。
一般情况下,J2EE应用服务器支持JDBC事务、JTA事务、容器管理事务。同时,最好不要在程序中同时使用上述三种事务类型,比如在JTA事务中嵌套JDBC事务;第二方面,事务要在尽可能短的时间内完成,不要在不同方法中实现事务的使用。比如,下面给出了回滚JDBC事务的代码示例:
public void processT(String orders) {
Context initCtx = new InitialContext();
javax.sql.DataSource ds = javax.sql.DataSource)initCtx.lookup("java:comp/env/jdbc/OrdersDB");
java.sql.Connection conn = ds.getConnection();
try{
conn.setAutoCommit( false ); // 更改JDBC事务的默认提交方式
orderNo = createOrder( orders );
updateOrderStatus(orderNo, "orders created");
conn.commit(); // 提交JDBC事务
}catch( Exception e ){
try{
conn.rollback(); // 回滚sJDBC事务
throw new EJBException("事务回滚:" e.getMessage());
}catch( SQLException sqle ){
throw new EJBException("出现SQL操作错误:" sqle.getMessage());
}
}
}
(修改自,Transactions in J2EE(RedBooks).pdf中的一段Bean管理的JDBC事务)
下面给出了JTA事务代码示例:
public void processOrder(String orderMessage) {
UserTransaction transaction = mySessionContext.getUserTransaction();// 获得JTA事务
try{
transaction.begin(); // 开始JTA事务
orderNo = sendOrder(orderMessage);
updateOrderStatus(orderNo, "order sent");
transaction.commit(); // 提交JTA事务
}catch(Exception e){
try{
transaction.rollback();// 回滚JTA事务
}catch(SystemException se){
se.printStackTrace();
}
throw new EJBException("事务回滚:" e.getMessage());
}
}
(修改自,Transactions in J2EE(RedBooks).pdf中的一段Bean管理的JTA事务)