Tomcat的数据源配置
Tomcat本身并不具备提供数据源的能力,它需要借助其他的开源数据源(如DBCP)类实现。通过Tomcat提供的数据源,我们的程序中可以通过JNDI来访问数据源。下面以DBCP为例,简介数据源的配置。
数据源的配置也有两种方式,一种是通过修改Tomcat系统文件来配置全局数据源,一种是通过增加用户的web部署文件来配置局部数据源。全局数据
源的意义是所有部署在Tomcat内的web应用只要遵循规定都可以访问的数据源,不建议此方式,可能会导致混乱。相对而言,增加用户自己的web部署文
件就比较合适一些,因为该数据源只针对某个web应用生效,其他web应用无法访问该数据源,安全一些,也没全局数据源那么混乱。
配置数据源需要数据源的jar文件,如DBCP数据源就需要在Tomcat的common/lib下增加一个commons-dbcp.jar文
件,还需要commons-poo.jar和commons-collections.jar的支持,一般在Tomcat里都会有这三个jar文件,最好
还是检查一下。
在Tomcat的conf\localhost下创建自己的web部署配置文件,仿佛见《Tomcat中部署web应用的方式》,在Context元素下增加子元素,以Oracle数据库为例,如:
<Resource name="jdbc/dataSource" auth="Container"
description="DB Connection"
type="javax.sql.DataSource"
username="username" password="password"
driverClassName="oracle.jdbc.driver.OracleDriver"
url="jdbc:oracle:thin:@192.168.0.10:1521:db" maxActive="5" />
程序中访问此数据源的代码:
//初始化Context
Context ctx = new InitialContext();
//获取数据源,其中java:comp/env是Tomcat规定的,Tomcat提供的JNDI绑定都必须加该前缀
DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/dataSource");
//获取数据库链接
Connection conn = ds.getConnection();
//一系列数据库操作
... ...
上面介绍了局部数据源的配置方法,全局数据源的配置和这差不多,只不过要是将Resource标签放在server.xml的<GlobalNamingResources>元素里。
页:
[1]