开发基于JBoss的J2EE应用(2)
2008-02-23 09:42:47来源:互联网 阅读 ()
??<sync-on-commit-only>false</sync-on-commit-only>
??。。。。。。。。。
完成上述两步后,读者在调试Entity Beans时通过控制台,可以看到Entity Beans发出的JDBC调用细节。
??(3)Tomcat容器相关参数的配置:
如果目标读者使用JBoss 3.2.1与Tomcat 4.1.24的集成版本,则可以通过调节分别位于目录:C:\jboss-3.2.1_tomcat-4.1.24\server\default\deploy\jbossWeb-tomcat.sar下的web.xml和目录:C:\jboss-3.2.1_tomcat-4.1.24\server\default\deploy\jbossweb-tomcat.sar\META-INF下的jboss-service.xml文件来达到目标读者特定需求。
比如,如果想将HTTP服务端口改为80,则可以修改jboss-service.xml文件;如果想使目标J2EE应用处理更多的文件类型,可以修改web.xml文件。
??(4)相关类库的放置:
如果您的应用涉及到第三方类库,比如JDBC Driver,则可以将这些JDBC Driver存放到目录下:C:\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(SystemException se){
??????se.printStackTrace();
?????}
????throw new EJBException("事务回滚:" e.getMessage());
???}
??}
??(修改自,Transactions in J2EE(RedBooks).pdf中的一段Bean管理的JTA事务)
同时,如果Session Bean采用JTA管理事务,一定不要通过JNDI获取JTA事务,否则结果不堪设想;而是采用类似,“mySessionContext.getUserTransaction()”的方法获取。
最后,可以使用容器管理事务(CMT)。在使用CMT过程中,如果声明让容器完成事务回滚,则目标EJB应用必须抛出系统级异常,否则容器是不会满足事务的ACID。在包javax.ejb的异常类中,除了NoSuchEntityException和EJBException属于系统级异常外,其他的异常全部是应用级异常。
上述3点内容,值得读者注意。可能有些读者在使用EJB CMT过程中,总是会遇到自己已经将事务声明为“Required”,但就是不能够保证事务的ACID。因此,希望读者注意J2EE应用中事务使用的不同方式。详细情况,可以参考J2EE Tutorial一书中的事务处理章节。
??另外,
??1) 在开发Entity Beans过程中,能够使用CMP的地方尽量不要采用BMP的方式。如果拟采用BMP的方式,还不如采用Session Bean JDBC,其中可以通过JTA控制事务(如果性能问题不是很重要的话)。
??2) 能够通过容器实现的事务(即,通过声明)的地方尽量采用,提高开发效率,使得您可以更加专注于业务逻辑本身。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:开发J2EE应用的要领
下一篇:一个大胆,史无前例的想法
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash
