Tomcat中context.xml配置各种数据库连接池

转载自:http://blog.163.com/samoyed_kk/blog/static/853760092008525462373/

有小小格式上的修改,以及连接MySQL时driverClassName的变动。


在tomcat下context.xml中配置各种数据库连接池  



Tomcat6的服务器配置文件放在 ${tomcat6}/conf 目录底下。我们可以在这里找到 server.xml 和 context.xml。当然,还有其他一些资源文件。但是在在本文中我们只用得上这两个,其他的就不介绍了。
1. 首先,需要为数据源配置一个JNDI资源。 我们的数据源JNDI资源应该定义在context元素中。 在tomcat6版本中,context元素已经从server.xml文件中独立出来了,放在一个context.xml文件中。因为server.xml是不可动态重加载的资源,服务器一旦启动了以后,要修改这个文件,就得重启服务器才能重新加载。而context.xml文件则不然,tomcat服务器会定时去扫描这个文件。一旦发现文件被修改(时间戳改变了),就会自动重新加载这个文件,而不需要重启服务器。 我们当然推荐把应用需要的JNDI资源配置在context.xml文件中,而不是server.xml文件中。


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


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


<Context reloadable="true">
        <Resource
                name="jdbc/数据库名"
                type="javax.sql.DataSource"
                maxActive="100"
                maxIdle="30"
                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"
 

通过java的jndi就可以了


        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="com.mysql.jdbc.Driver" 
        url="jdbc:mysql://localhost/数据库名"  
        username="用户名" 
        password="密码" 
        maxActive="100" //最大连结数 
        maxIdle="30" //最大空闲时间,0为无限制 
        maxWait="10000"/> //建立连接的的最大等待时间
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值