zoukankan      html  css  js  c++  java
  • 在tomcat下context.xml中配置各种数据库连接池(JNDI)

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

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

    2、将下面的代码放到Tomcat 6.0confcontext.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 FilesApache Software FoundationTomcat 5.5confcontext.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="org.gjt.mm.mysql.Driver" 
    url="jdbc:mysql://localhost/数据库名"  
    username="用户名" 
    password="密码" 
    maxActive="100" //最大连结数 
    maxIdle="30" //最大空闲时间,0为无限制 
    maxWait="10000"/> //建立连接的的最大等待时间

  • 相关阅读:
    天使投资家李镇樟:如何培养世界级企业家
    [案例分析] 打造值得信任的个人品牌究竟靠什么?
    怎能相逢
    企业的创新和创新的双面性
    给创业者的忠告:中国互联网的柏金森定律
    梦想的婚礼
    企业人,需守候精神商业的价值
    我与东方
    五种成功创业模式让你轻松赚到钱
    一招一式, 成就“霸业”必做的9件大事
  • 原文地址:https://www.cnblogs.com/borter/p/9578148.html
Copyright © 2011-2022 走看看