本文介绍JBOSS EAP 6.2中Oracle数据源的配置方式。结合之前JBOSS EAP 6.2新功能,本文初识JBOSS模块申明式容器这一特性。
模块申明式容器:JBOSS EAP不再有lib的概念,一切都是module。无论是系统调用的lib,用户编制的lib,或者应用程序引用到的第三方lib都以模块的方式构建起来,并在使用的地方申明具体使用哪个模块。
以下分三步介绍数据源的配置:
将数据库驱动构建为JBOSS内的模块
为JBOSS容器加载驱动模块
为JBOSS容器配置数据源
1、将数据库驱动构建为JBOSS内的模块
数据源驱动程序是JAVA获得与数据源连接的接口,可以理解为上面提到的系统调用的lib,所以我们需要将数据源驱动程序构建为一个JBOSS模块,构建分两个步骤:
将资源放置到正确的位置:%JBOSS_EAP_HOME%/modules目录下
将资源配置为一个JBOSS模块:module.xml文件的编写
接下来以Oracle为例,构建一个Oracle driver module
1. 创建目录%JBOSS_EAP_HOME%/modules/com/oracle/main/,存放oracle驱动程序:ojdbc14.jar (对应Oracle 10g)
2. 在main中创建moduel.xml配置文件
其中:
指明这个模块的名称com.oracle供其他模块设置依赖;
指明模块的资源名称,资源要与module.xml在同一个文件夹下;
指明该模块所依赖的模块,如module.xml中指明的两个模块也是像构建这恶搞Oracle数据源模块一样实现的,它们可以%JBOSS_EAP_HOME%/modules下找到:
jboss-eap-6.1\modules\system\layers\base\javax\api\main
jboss-eap-6.1\modules\system\layers\base\javax\transaction\api\main
【Module配置小扩展】
资源可以是jar包,也可以是一个文件夹,如系统默认配置:jboss-eap-6.2\modules\system\layers\base\sun\jdk\main
严格的讲只要配置文件和资源在一起就行,只要是modules目录下,具体在什么位置都没关系,但需要注意的是标签中的name要与资源所在的modules下的目录相匹配。
module.xml可以映射别的已有的module,如系统默认配置:jboss-eap-6.2\modules\system\layers\base\org\apache\commons\logging\main\module.xml
2、为JBOSS容器加载驱动模块
JBoss容器的配置文件在%JBOSS_EAP_HOME%\standalone\configuration中,集群的配置文件在E:\server\jboss-eap-6.1\domain\configuration中
我们主要看单个主机的%JBOSS_EAP_HOME%\standalone\configuration\standalone.xml
打开standalone.xml首先看到的就是如:
每一项都是模块module,他们对应的都是如第一步配置的数据源驱动模块一样的资源,standalone.xml为容器指明并加载这些需要用到的默认的资源。
简单说下standalone有四个部分:
extensions:加载容器默认使用的模块
manangement:配置容器管理
profile:容器使用的子系统配置
interfaces:容器对外可接入性的配置
socket-binding-group:容器中的服务与机器端口的绑定
后续的文章中再回头介绍standalone配置文件的常用配置,这里就不过多赘述。
数据源属于容器的子系统,所以在profile中子标签下加载
配置数据源,在第三步中要用到
配置数据源驱动
因为不知道会用到什么样的数据源,所以在之前默认加载的extensions中没有任何模块指定这个数据源驱动的module。我们需要在中加载,oracleDS为例可添加如下标签,
oracle.jdbc.OracleDriver
oracle.jdbc.xa.client.OracleXADataSource
其中,标签中的module属性就是我们在第一步中创建的module.xml中的name:
*这里实际上配了两个driver,一个是一般dataSource的一个是xa-dataSource,xa-dataSource在本文最后有简要补充。
3、为JBOSS容器配置数据源
最后步来配置数据源,也就是标签,因为都是基础配置,所以直接上代码:
jdbc:oracle:thin:@192.168.*.*:1521:orcl
oracle.jdbc.OracleDriver
oracle
yaoyu
yaoyu
false
false
false
其中中的部分对应的就是之前第二步中的name
Oracle的数据源这样就配好了。
测试的话可以打开Web-console中的DataSource向中的Test Connection来尝试连接该数据源。
*扩展:XA-DataSource的配置
界面上能看到DataSource 和XA-DataSource,这其实是两种数据源的配置方式,XA是“Globle Transaction”的意思,更具体的参照/Jeffery001/archive//08/30/330054.html。
需要配XA-DS的,第一步配置驱动模块一样用的也是同一个jar,不同的是在第二步的中加了xa-datasource,在第三步如下配置
oracle
jdbc:oracle:oci8:@tc
admin
admin123
false
oracle.jdbc.xa.client.OracleXADataSource
总结
本文介绍的是Oracle数据源在JBOSS EAP 6.1中的配置(配置适用JBOSS AS7),分3个步骤完成:
1、将数据库驱动构建为JBOSS内的模块
2、为JBOSS容器加载驱动模块
3、为JBOSS容器配置数据源
除了配置外主要对JBOSS EAP 6.2的“模块申明式容器”这一特征有个简单的认识