在tomcat下context.xml中配置各类数据库链接池(转)

Tomcat6的服务器配置文件放在 ${tomcat6}/conf 目录底下。咱们能够在这里找到 server.xml context.xml。固然,还有其余一些资源文件。可是在在本文中咱们只用得上这两个,其余的就不介绍了。java

1. 首先,须要为数据源配置一个JNDI资源。 咱们的数据源JNDI资源应该定义在context元素中。 tomcat6版本中,context元素已经从server.xml文件中独立出来了,放在一个context.xml文件中。由于server.xml是不可动态重加载的资源,服务器一旦启动了之后,要修改这个文件,就得重启服务器才能从新加载。而context.xml文件则否则,tomcat服务器会定时去扫描这个文件。一旦发现文件被修改(时间戳改变了),就会自动从新加载这个文件,而不须要重启服务器。 咱们固然推荐把应用须要的JNDI资源配置在context.xml文件中,而不是server.xml文件中。mysql

1、首先,将数据库的驱动程序copytomcat6.0\lib下,这一部是关键,若是没有copy 当运行程序的时候后报-找不到驱动-的异常。sql

2、将下面的代码放到Tomcat 6.0\conf\context.xml中间,如:数据库

<Context reloadable="true">tomcat

<Resource服务器

name="jdbc/数据库名"oracle

type="javax.sql.DataSource"jsp

maxActive="100"sqlserver

maxIdle="30"url

maxWait="5000"

username="用户名"

password="密码"

driverClassName="数据库的驱动"

url="数据库的链接地址" />

</Context>

解释:(100 30 5000 为上面的数据)

maxActive="最大能够有100名用户链接数据源"

maxIdle="若是没有用户链接,空出30个链接等待用户链接"

maxWait="若是已链接用户5000秒内没有再次链接数据源,则放弃此链接"

完成这两部,数据源就能够用了。

另外,也能够在项目root下的WEB-INF下新建context.xml进行配置

<?xml version="1.0" encoding="UTF-8"?>

<Context>/////直连

<Resource

name="jdbc/book"

type="javax.sql.DataSource"

password=""

driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"

maxIdle="5"

maxWait="5000"

username="sa"

url="jdbc:microsoft:sqlserver://localhost:1433;databaseName=book"////直连数据源

maxActive="10"/>

</Context>

<!-->

<Context>////桥连

<Resource

name="jdbc/book"

type="javax.sql.DataSource"

password=""

driverClassName="sun.jdbc.odbc.JdbcOdbcDriver"

maxIdle="2"

maxWait="5000"

username="sa"

url="jdbc:odbc:bb"///桥连的数据源

maxActive="4"/>

<WatchedResource>C:\Program Files\Apache Software Foundation\Tomcat 5.5\conf\context.xml</WatchedResource>

</Context>

<!-->

直接在Context文件中加入:

<Resource

name="jdb/dbsource"

type="javax.sql.DataSource"

driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"

maxIdle="2"

maxWait="5000"

url="jdbc:microsoft:sqlserver://localhost:1433;databaseName=jspdev"

maxActive="4"/>

username="he"

password="he"

经过javajndi就能够了

InitialContext initCtx = new InitialContext();
DataSource ds = (DataSource)initCtx.lookup("java:comp/env/jdbc/
数据库名");
Connection conn = ds.getConnection();

如下是各类数据库的配置

1.sql2000

<Resource
name="jdbc/
数据库名"

type="javax.sql.DataSource"

maxActive="100"

maxIdle="30"

maxWait="5000"

username="用户名"

password="密码"

driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"

url="jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=数据库名"
/>

2.oracle

<Resource
name="jdbc/
数据库名"
type="javax.sql.DataSource"
maxActive="100"
maxIdle="30"
maxWait="5000"
username="
用户名"
password="
密码"
driverClassName="oracle.jdbc.driver.OracleDriver"
url="jdbc:oracle:thin:@127.0.0.1 :1521:ora9"
/>

3.mysql

<Resource name="jdbc/mysql"
auth="Container"
type="javax.sql.DataSource" //
资源类型
driverClassName="org.gjt.mm.mysql.Driver"
url="jdbc:mysql://localhost/
数据库名"
username="
用户名"
password="
密码"
maxActive="100" //
最大连结数
maxIdle="30" //
最大空闲时间,0为无限制
maxWait="10000"/> //
创建链接的的最大等待时间

相关文章
相关标签/搜索