置数据库资源
大多数企业应用程序使用关系数据库。Community Edition 使用开放源代码的 TranQL 项目作为其数据库持久性引擎。Community Edition 提供一般资源适配器来使 JDBC 驱动程序可以作为 J2EE Connection Architecture (J2CA) 资源使用,并提供特定于 IBM Cloudscape 供应商的资源适配器来使 Cloudscape 可以作为 Tranql 的 J2CA 资源使用。作为一种增值,Community Edition 还提供一个 WebSphere 嵌入式资源适配器来使 Microsoft SQL 2000 服务器可以作为 J2CA 资源使用。了解 Community Edition 存储库中的下列文件将有助于您为数据源选择正确的资源适配器以及制定数据库部署计划:
- repository\tranql\rars\
- tranql-connector-1.0.rar:这是 TranQL Generic JDBC Resource Adapter,使用该资源适配器,可以通过一般 JDBC 连接来访问 SQL 数据库。连接是使用配置的 JDBC URL、用户名和密码从 java.sql.Driver 获得的。因为此接口不提供对 XAResource 的访问,所以只支持 Local 事务。
- tranql-connector-derby-client-local-1.0.rar:这是用于 IBM Cloudscape 的 TranQL Client Local Transaction Resource Adapter。该资源适配器提供对具有本地事务支持的远程 IBM Cloudscape 数据库的访问。
- tranql-connector-derby-client-xa-1.0.rar:这是用于 IBM Cloudscape 的 TranQL Client XA Transaction Resource Adapter。该资源适配器提供对具有 XA 事务支持的远程 IBM Cloudscape 数据库的访问。
- tranql-connector-derby-embed-local-1.0.rar:这是用于 IBM Cloudscape 的 TranQL Embedded Local Resource Adapter。该资源适配器提供对具有本地事务支持的嵌入式 IBM Cloudscape 数据库的访问。
- tranql-connector-derby-embed-xa-1.0.rar:这是用于 IBM Cloudscape 的 TranQL Embedded XA Resource Adapter。该资源适配器提供对具有 XA 事务支持的嵌入式 IBM Cloudscape 数据库的访问。
- tranql-connector-websphere-embed-local-1.0.rar:这是用于 Microsoft SQL 2000 服务器的 TranQL IBM WebSphere Connect JDBC Driver Embedded Local Resource Adapter。该资源适配器提供对具有本地事务支持的 Microsoft SQL 2000 服务器数据库的访问。
- tranql-connector-websphere-embed-xa-1.0.rar:这是用于 Microsoft SQL 2000 服务器的 TranQL IBM WebSphere Connect JDBC Driver Embedded XA Resource Adapter。该资源适配器提供对具有 XA 事务支持的 Microsoft SQL 2000 服务器数据库的访问。
- 上面提到的所有 TranQL rar 文件都包含在
tranql-1.1.ibm.jar
文件中,该文件是数据库持久性引擎。
- repository\org.apache.derby\jars:这个目录包含 IBM Cloudscape 数据库服务器 jar 文件。
- repository\websphere\jars:这个目录包含用于 Microsoft SQL 2000 数据库服务器的 WebSphere 嵌入式 JDBC 驱动程序。
您可能想知道为什么尽管 Community Edition 支持前面提到的 Oracle、DB2 或 MySQL 数据库,但是却没有看到特定于这些数据库的任何资源适配器。这是因为用于 Oracle、DB2 和 MySQL 数据库服务器的 JDBC 驱动程序并没有包含在 Community Edition 安装镜像中。相反,将使用一般资源适配器 (tranql-connector-1.0.rar
) 来部署用于 Oracle、DB2 和 MySQL 数据库服务器的数据源,并将必需的特定于数据库的类复制到 Community Edition 存储库中。与此有关的更多信息将在本文后面介绍。
Community Edition 支持下列三种数据库配置池类型。您可以确定您的 J2EE 应用程序需要哪种数据库配置池类型。
- 服务器范围的数据源:它用于在服务器上运行的所有应用程序。Community Edition 提供的 EMPdemo 示例使用该服务器范围的数据源。
- 应用程序范围的数据源:它用于同一个应用程序的一个或多个模块。
- 模块范围的数据源:它只用于应用程序中的某个特定模块。Community Edition 提供的 daytrader 示例使用该模块范围的数据源。
不管您决定使用哪种数据库配置池类型,您都需要制定一个数据库池部署计划。在数据库池部署计划中,您可以指定数据源配置 ID、其父 ID、依赖项和资源适配器配置信息,例如数据源名称、池大小的最小值和最大值。通过使用 EMPdemo 示例提供的数据库池部署计划,我们将向您介绍如何理解和修改此计划以制定自己的数据库部署计划。
- 定义数据源配置 ID 和父 ID:数据库部署计划的下列部分指定
configId
,对于 Community Edition 服务器实例,它必须是唯一的。如果在部署数据源时父 ID(parentId
的值)没有运行,则部署工具会首先启动该父 ID 以确保其可用。在 EMPdemo 示例中,数据库部署计划的这一部分对不同的数据库服务器来说是一样的(清单 1)。
清单 1:EMPdemo Cloudscape 数据库池部署计划(第 I 部分)
<?xml version="1.0"?>
<connector xmlns="http://geronimo.apache.org/xml/ns/j2ee/connector-1.0"
configId="EmployeeDatasource" parentId="org/apache/geronimo/Server">
- 定义依赖元素:
dependency
元素定义所有数据源依赖项及其相对于 Community Edition 存储库的相对路径(清单 2)。IBM Cloudscape 数据库服务器及其特定于供应商的 tranql 资源适配器是随 Community Edition 一起提供的,所以您不必担心要将 jar 文件复制到存储库中。通过将它们指定为依赖项,您可以免于将它们包含在自己的应用程序中。
清单 2:EMPdemo Cloudscape 数据库池部署计划(第 II 部分)
<dependency>
<uri>org.apache.derby/jars/derby-10.1.ibm.jar</uri>
</dependency>
<dependency>s
<uri>org.apache.derby/jars/derbynet-10.1.ibm.jar</uri>
</dependency>
正如前面提到的,Community Edition 也包含用于 Microsoft SQL 2000 服务器的 WebSphere 嵌入式 Tranql 资源适配器和 WebSphere 嵌入式类型 4 JDBC 驱动程序(jar 文件在repository\websphere\jars
目录中)。根据这一事实,您可以提供以下访问 Microsoft SQL 2000 服务器的数据源的依赖元素(清单 3)。
清单 3:EMPdemo Microsoft SQL 数据库池部署计划(第 II 部分)
<dependency>
<uri>websphere/jars/base-3.5.11.jar</uri>
</dependency>
<dependency>
<uri>websphere/jars/util-3.5.11.jar</uri>
</dependency>
<dependency>
<uri>websphere/jars/sqlserver-3.5.11.jar</uri>
</dependency>
如果您要为 Oracle、DB2 或 MySQL 服务器构建dependency
元素,则可以遵循相同的模式。但是,您需要在 Community Edition 存储库中创建目录和子目录,将 JDBC 驱动程序 jar 文件从数据库服务器复制到新建的目录中,并在尝试部署数据库部署计划之前在 uri 依赖元素中指定该 jar 文件及其路径。
- 配置资源适配器
- IBM Cloudscape 数据库:配置用于 IBM Cloudscape 的资源适配器非常简单,因为 Community Edition 已经提供了特定于 Cloudscape 的资源适配器。您不需要输入 JDBC 驱动程序信息。如果您将
CreateDatabase
属性设置为 True,则也不需要事先创建数据库。如果您利用下面的示例,则只需要修改name
、UserName
、Password
、DatabaseName
和CreateDatabase
元素并配置数据库池,这样就可以构建自己的用于 Cloudscape 的资源适配器配置(清单 4)。name
元素定义其他模块将用于引用此连接池的名称。它在您定义的数据库池范围内必须是唯一的。例如,jdbc/EmployeeDatasource 在服务器范围内必须是唯一的,因为该配置用于服务器范围的数据源。您还需要指定name
、UserName
、Password
、DatabaseName
和CreateDatabase
元素。max-size
元素定义允许的最大并发连接数。min-size
元素定义允许的最小并发连接数。blocking-timeout-milliseconds
元素定义在从池中获取连接时等待的毫秒数,此后将放弃连接。idle-timeout-minutes
元素定义在连接关闭并从池中删除之前可以保持空闲状态的分钟数。
您可能还想知道为什么将global-jndi-name
元素注释掉了。这是因为在尝试从 J2EE 应用程序客户端连接到数据源时才使用该元素。EMPdemo 示例中没有 J2EE 应用程序客户端。有关 Cloudscape 资源适配器的详细信息,请参见tranql-connector-derby-client-local-1.0.rar
、tranql-connector-derby-client-xa-1.0.rar
、tranql-connector-derby-embed-local-1.0.rar
和tranql-connector-derby-embed-xa-1.0.rar
文件中的ra.xml
文件。
清单 4:EMPdemo Cloudscape 数据库池部署计划(第 III 部分)
<resourceadapter>
<outbound-resourceadapter>
<connection-definition>
<connectionfactory-interface>javax.sql.DataSource
</connectionfactory-interface>
<connectiondefinition-instance>
<name>jdbc/EmployeeDatasource</name>
<config-property-setting name="UserName">
</config-property-setting>
<config-property-setting name="Password">
</config-property-setting>
<config-property-setting name="DatabaseName">Employee
</config-property-setting>
<config-property-setting name="CreateDatabase">true
</config-property-setting>
<connectionmanager>
<xa-transaction>
<transaction-caching/>
</xa-transaction>
<single-pool>
<max-size>5</max-size>
<min-size>0</min-size>
<blocking-timeout-milliseconds>5000
</blocking-timeout-milliseconds>
<idle-timeout-minutes>15</idle-timeout-minutes>
<match-one/>
</single-pool>
</connectionmanager>
<!--global-jndi-name>EmployeeDatasource</global-jndi-name-->
</connectiondefinition-instance>
</connection-definition>
</outbound-resourceadapter>
</resourceadapter>
</connector>
- Oracle 数据库:正如前面提到的,Community Edition 提供了特定于 IBM Cloudscape 和 Microsoft SQL Server 2000 的资源适配器。对于 Oracle、DB2 或 MySQL 数据库,您需要使用一般资源适配器,它允许您为 JDBC 驱动程序指定 Driver 和 ConnectionURL(清单 5)。有关一般资源适配器的详细信息,请参见
tranql-connector-1.0.rar
文件中的ra.xml
文件。
清单 5:EMPdemo Oracle 数据库资源适配器配置
...
<config-property-setting name="UserName">wasce</config-property-setting>
<config-property-setting name="Password">password</config-property-setting>
<config-property-setting name="Driver">oracle.jdbc.driver.OracleDriver</
config-property-setting>
<config-property-setting name="ConnectionURL">jdbc:oracle:thin:
@oracleServer.ibm.com:1521:orcl</config-property-setting>
...
- IBM DB2 数据库:IBM DB2 数据库资源适配器配置与 Oracle 相同,唯一不同之处在于需要指定特定于 DB2 的
UserName
、Password
、Driver
和ConnectionURL
元素(清单 6)。
清单 6:Daytrader DB2 数据库资源适配器配置
...
<config-property-setting name="UserName">db2inst1</config-property-setting>
<config-property-setting name="Password">password</config-property-setting>
<config-property-setting name="Driver">com.ibm.db2.jcc.DB2Driver</config-property-setting>
<config-property-setting name="ConnectionURL">jdbc:db2://db2.raleigh.ibm.com:50001/tradedb
</config-property-setting>
...
- Microsoft SQL 2000 服务器:作为 Apache Geronimo 的一种增值,Community Edition 提供了用于 Microsoft SQL 2000 服务器的 WebSphere 嵌入式 Tranql 资源适配器,它为您处理
Driver
和ConnectionURL
信息,所以您只需要指定 ServerName 和 DatabaseName(清单 7)。如果您的 SQL Server 在不同于缺省端口 (1433) 的其他端口上运行,则可以在DatabaseName
元素之后指定PortNumber
属性。有关资源适配器的详细信息,请参见tranql-connector-websphere-embed-local-1.0.rar
和tranql-connector-websphere-embed-xa-1.0.rar
文件中的ra.xml
文件。
清单 7:EMPdemo Microsoft SQL 数据库资源适配器配置
...
<config-property-setting name="UserName">wasce</config-property-setting>
<config-property-setting name="Password">password</config-property-setting>
<config-property-setting name="ServerName">servername.ibm.com</config-property-setting>
<config-property-setting name="DatabaseName">wascedb</config-property-setting>
...
- IBM Cloudscape 数据库:配置用于 IBM Cloudscape 的资源适配器非常简单,因为 Community Edition 已经提供了特定于 Cloudscape 的资源适配器。您不需要输入 JDBC 驱动程序信息。如果您将
部署数据库池:您已经了解了如何制定数据库部署计划,以及对于不同的数据库服务器应该使用什么资源适配器。现在,我们来演练如何在 Community Edition 服务器上使用 bin 目录中的部署工具来部署数据库池(清单 8)。
清单 8:部署 EMPdemo Cloudscape 数据源
|
在运行部署命令的命令窗口中,您将看到一个指示数据库池是否已经部署成功的输出。必要时替换管理员用户名和密码。如果您想要使用其他资源适配器,则可以用您选择的资源适配器来替换上面的 rar 文件。例如,如果您部署 EMPdemo Oracle 数据库,则将 tranql-connector-derby-embed-xa-1.0.rar
替换为 tranql-connector-1.0.rar
,将 Cloudscape-db-plan 替换为 EMPdemo Oracle 数据库部署计划 (oracle-db-plan.xml
)。
修改数据库池:该部署工具并没有提供修改命令。要修改数据库池,您需要取消部署该数据库池然后再部署它。
要使用您刚部署的数据库池,请定义 Apache Geronimo 部署计划中的特定资源引用来引用它(清单 9)。您还需要在 web.xml
中声明该资源引用,并在应用程序代码中通过 JNDI 查找数据库池。有关详细信息,可以查看 EMPdemo home 目录中的 src\webapp\WEB-INF\web.xml
和src\webapp\jsp\EMPdemo.jsp
文件。
清单 9:EMPdemo 部署计划中的 resource-ref 元素
|
Java Message Service (JMS) 支持在不同的应用程序组件之间发送消息,即使在分发时也如此。消息驱动 Bean 使用 JMS 来接收消息,然后可能根据这些消息来采取某种操作。
Community Edition 中的 JMS 支持是由 ActiveMQ 提供的。ActiveMQ 是一个 JMS 1.1 提供程序,它完全支持遵循 J2EE 1.4 的服务器,包括 Community Edition。它还包含一个 Java Connector Architecture (JCA) 1.5 资源适配器,该资源适配器允许应用服务器连接到池、管理事务和控制连接器安全性。对 JMS 资源的访问是由遵循 ActiveMQ JCA 的资源适配器提供的。目前,ActiveMQ 是唯一已知可以用于 Community Edition 的 JMS 提供程序。
ActiveMQ 服务器(或消息代理)在缺省情况下是在 Community Edition 服务器启动时启动的。其配置 (org/apache/geronimo/ActiveMQServer
) 是在 system-activemq-plan.xml
(可以在 wasce_install_root/doc/plan 目录中找到)中定义的。此配置包括两个传输:一个在端口 61616 上运行的 TCP 传输和一个在相同 JVM 上运行的客户端的直接传输(清单 10)。ActiveMQ 支持的其他传输包括 SSL、NIO、UDP、多播、JGroup 和 JXTA 传输。
清单 10:在 system-activemq-plan.xml 中定义的传输
|
消息代理配置的建议更改方式是使用 config.xml 来配置正确的属性。有关使用 config.xml 来配置服务器属性的更多信息,请参见第 1 部分。问题在于,在实际操作中很难确定哪些是正确的 gbean 属性以及它们是否是可管理的。另外,建议不要重新部署 system-activemq-plan.xml,因为这种方式以后会导致问题的出现。如果您知道属性名称(以及它们是否可管理),则可以通过编辑 config.xml 来更改这些计划,然后重新部署它们。
消息代理仅在有配置目标时才有用。在 Community Edition 中创建和配置这些资源意味着部署一个带有如何与消息代理通信的信息的资源适配器实例。要获得示例,请查看 system-jms-plan.xml
(可以在 wasce_install_root/doc/plan 目录中找到)。此计划将创建一个资源适配器实例和一个连接工厂,后者是创建供内部使用的两个队列(MDBTransferBeanOutQueue 和 SendReceiveQueue)所需要的(清单 11)。
清单 11:system-jms-plan.xml 中定义的连接器
|
要创建自己的资源适配器实例,您可以从 system-jms-plan.xml
计划复制连接器元素,为其提供自己的 configId
,并用自己的队列和主题来替换其队列。将连接器元素复制到哪里取决于您想让连接器实例拥有的作用域。您可以将资源适配器定义和部署为对所有其他模块可见的独立连接器,方法是将其放在自己的计划中并用对 activemq rar 文件的引用来部署它:
|
另一种选择是在应用程序或模块范围内创建资源适配器实例。
dayTrader 示例应用程序是一个拥有自己的资源适配器实例的应用程序示例。它引用一个队列 (TradeBrokerQueue
) 和一个主题 (TradeStreamerTopic
)。这些资源的定义可以在 daytrader-plan.xml 中的一个 ext-module
元素内找到(清单 12)。通过 ext-module
元素 dayTrader,您可以使用现有的 Active MQ 连接器副本,而不必将其包含在应用程序中。
清单 12:dayTrader 的 JMS 资源使用现有的 Active MQ 连接器副本
|
system-jms-plan.xml 中的资源适配器实例和 daytrader-plan.xml 中的资源适配器实例都是使用相同的信息配置的:如何连接到 JMS 服务器、在创建新的资源时队列和主题连接工厂应该使用什么设置,以及对队列和主题的引用。这些与您在配置自己的资源适配器实例时需要提供的信息是相同的。
该连接器中的 adminobject
元素的作用在于将应用程序的 J2EE 描述符中声明的消息目的地引用与真正的物理目的地连接起来。例如,在 daytrader 的 ejb-jar.xml 文件中声明了用于 TradeBrokerQueue
和 TradeStreamerStopic
的 message-destination-ref
元素(清单 13)。
清单 13:ejb-jar.xml 中 dayTrader 的消息目的地引用
|