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

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

表示层:

在表示层,由两个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>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航