\jboss-3.2.1_tomcat-4.1.24\server\default\lib。注意,不是目录:C:\jboss-3.2.1_tomcat-4.1.24\lib下。 如果是与目标J2EE应用相关,则可以存放到目标.war(或者.ear)里面,或者xxx.war目录中的WEB-INFO\lib下。无论那种情形,都需要遵循J2EE规范。 当然,JBoss 3.2.1的配置文件有很多,比如提供邮件服务的mail-service.xml文件,等等。在这里只是给读者一些信息,如果您有相关问题,都可以试着本文介绍的一些内容解决您的
问题。谢谢。
二,开发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(Sys