使用JOTM为Servlets增加事务支持(3)

类别:Java 点击:0 评论:0 推荐:

表示层:

在表示层,由两个JSP文件组成:

atm.jsp:现金支取应用,用于发送用户信息和需要支取的现金数额到bar.CashDelivery类,并显示用户操作的结果。

admin.jsp:管理控制台用于显示和更新与两个资源有关的信息。(并非程序设计的一部分,但是必须要添加以便使资源更新操作变得简单,比如向用户账户存钱)

图1  应用程序设计

 

配置数据库:

关于数据库,我们使用MySQL 4.0.12和附带的JDBC驱动。MySql缺省不提供事务支持,为了让其支持事务,在创建表的时候必须声明是InnoDB类型。另外,为了能够提供InnoDB类型支持,你必须将MySQL配置文件(my.cnf)中的#skip-innodb一行注释起来。

在本例中设置MySQL用户为javauser,口令为javaude,需要确认该用户已经被创建并且具有创建数据库的权限。

创建数据库和表的脚本在示例文件的scripts/目录下。运行脚本文件将会创建account表并插入两条用户记录:

john_doe账户上有100元

jane_doe账户上有600元。

 

示例二:创建account表

mysql> CREATE DATABASE banktest;

mysql> USE banktest;

mysql> CREATE TABLE account(

    -> client VARCHAR(25) NOT NULL PRIMARY KEY,

    -> money INT) TYPE=InnoDB;

mysql> INSERT INTO account VALUES("john_doe", 100);

mysql> INSERT INTO account VALUES("jane_doe", 600);

mysql> SELECT * FROM account;

+----------+-------+

| client   | money |

+----------+-------+

| john_doe |   100 |

| jane_doe |   600 |

+----------+-------+

脚本文件同样会创建ATM表,并提供可以支取500元现金的记录:

 

示例三:创建atm表

mysql> CREATE DATABASE atmtest;

mysql> USE atmtest;

mysql> CREATE TABLE atm(

    -> id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,

    -> cash INT) TYPE=InnoDB;

mysql> INSERT INTO atm VALUES(null, 500);

mysql> SELECT * FROM atm;

+----+------+

| id | cash |

+----+------+

|  1 |  500 |

+----+------+

最后,你需要拷贝JDBC驱动到$Tomcat安装目录$/shared/lib目录下。

 

获取并安装Tomcat

本文基于Tomcat 4.1.18及以上版本编写,请确认你没有使用以前的版本,安装Tomcat并没有任何特殊之处,只需要下载并解压缩就可以了。

 

获取并安装JOTM

为了要使用JOTM,你必须从最新的二进制发行版下载并解压缩,从lib目录拷贝*.jar文件(除了log4j.jar、common-cli.jar和jotm_iiop_stubs.jar之外)到$Tomcat安装目录$/shared/lib目录下,一切都完成了。

 

配置Tomcat

你现在需要配置Tomcat以便使其能够从JNDI中获取UserTransaction和DataSource对象(用于foo.BankAccount和bar.ATM中)。

首先,告诉Tomcat在你的Web应用中会用什么JNDI名字寻找数据源。这项工作在web.xml文件中完成,下面列出了web.xml文件的内容。对于银行账户数据源,JNDI名字为java:comp/env/jdbc/bankAccount,但是你只需要给出在java:comp/env/之后的名字。Tomcat会使用JNDI机制解析余下部分的内容。对于ATM数据源也同样处理。

 

示例四:web.xml

<web-app>

    <resource-env-ref>

        <description>Bank Account DataSource</description>

        <resource-env-ref-name>jdbc/bankAccount</resource-env-ref-name>

        <resource-env-ref-type>javax.sql.DataSource</resource-env-ref-type>

    </resource-env-ref>

 

    <resource-env-ref>

        <description>ATM DataSource</description>

        <resource-env-ref-name>jdbc/ATM</resource-env-ref-name>

        <resource-env-ref-type>javax.sql.DataSource</resource-env-ref-type>

    </resource-env-ref>

</web-app>

现在你需要告诉Tomcat如何检索定义在web.xml中的资源,这些工作在bank.xml文件中完成,下面列出了bank.xml文件的内容。对于银行账户和ATM资源,必须设置正确的参数以便Tomcat将数据源与你的Web应用联系起来。更详细的描述可以在Tomcat JNDI How-to文档中找到。

 

有一个参数非常特别:factory。使用该参数设置的类会在Web应用查找JNDI时创建一个数据源。另一个在web.xml中描述的重要资源是UserTransaction。这项资源被java:comp/UserTransaction用来区分是否使用事务支持。该项资源的实现是JOTM提供的。

 

示例五:bank.xml

<Context path="/bank" docBase="bank.war" debug="0" reloadable="true" crossContext="true">

 

    <!-- Description of the DataSource "jdbc/bankAccount" -->

    <Resource name="jdbc/bankAccount" auth="Container" type="javax.sql.DataSource" />

    <ResourceParams name="jdbc/bankAccount">

        <parameter>

            <!-- Factory of the DataSource -->

            <name>factory</name>

            <value>org.objectweb.jndi.DataSourceFactory</value>

        </parameter>

        <parameter>

            <name>url</name>

            <value>jdbc:mysql://localhost/banktest</value>

        </parameter>

        <!-- other parameters include:

        o username - name of database user

        o password - password of the database user

        o driverClassName - JDBC Driver name

        -->

        ...

    </ResourceParams>

 

    <!-- Description of the DataSource "jdbc/ATM" -->

    <Resource name="jdbc/ATM" auth="Container" type="javax.sql.DataSource" />

 

    <!-- same type of parameters than for resource "jdbc/bankAccount" -->

    <ResourceParams name="jdbc/ATM">

        ...

    </ResourceParams>

 

    <!-- Description of the resource "UserTransaction -->

    <Resource name="UserTransaction" auth="Container" type="javax.transaction.UserTransaction" />

    <ResourceParams name="UserTransaction">

        <parameter>

            <name>factory</name>

            <value>org.objectweb.jotm.UserTransactionFactory</value>

        </parameter>

        <parameter>

            <name>jotm.timeout</name>

            <value>60</value>

       </parameter>

    </ResourceParams>

</Context>

本文地址:http://com.8s8s.com/it/it16551.htm