首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

tomcat jndi dhcp配备(一)

2012-10-18 
tomcat jndi dhcp配置(一)第一步:配置数据源在自己的工程里webroot目录的meta-inf下添加一context.xml文件

tomcat jndi dhcp配置(一)
第一步:配置数据源
    在自己的工程里webroot目录的meta-inf下添加一context.xml文件,内容如下:
<Context>
    <Resource name="jdbc/sqlserver"
auth="Container"
type="javax.sql.DataSource"
maxActive="20"
maxIdel="10"
maxWait="1000"
username="sa"
password="***"
driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"
url="jdbc:sqlserver://10.0.0.1:1400;DatabaseName=database">
    </Resource>
</Context>
注意:此内容也可以添加到tomcat的conf目录server.xml里,但是这样定义的是全局的数据源,影响以后的扩展。
某些名字的含义:
auth:指定管理Resource的Manager,由两个可选值:Container和Application。Container表示由容器来创建和管理 Resource,Application表示由WEB应用来创建和管理Resource。如果在web application deployment descriptor中使用<resource-ref></resource-ref>,这个属性是必需的,如果使用<resource-env-ref></resource-env-ref>,这个属性是可选的。
type:指定Resource所属的java类名。
maxActive:指定数据库连接池中处于活动状态的数据库连接最大数目,0表示不受限制。
maxIdel:指定数据库连接池中处于空闲状态的数据库连接的最大数目,0表示不受限制。
maxWait:指定数据库连接池中的数据库连接处于空闲状态的最长时间(单位为毫秒),超过这一事件,将会抛出异常。-1表示可以无限期等待。

第二步:添加源数据的引用
    在工程的web.xml中添加如下内容:
<resource-ref>
    <description>JNDI DataSource for SqlServer2005</description>
    <res-ref-name>jdbc/sqlserver</res-ref-name>
    <res-type>javax.sql.DataSource</res-type>
    <res-auth>Container</res-auth>
</resource-ref>
注意:此内容若不添加,也不影响程序运行,至于什么原因尚不得而知,望各种大虾赐教。

第三步:编写连接代码
    Context initCoxt = new InitialContext();
    DataSource ds = (DataSource)initCoxt.lookup("java:/comp/env/jdbc/sqlserver");
    strConnection = ds.getConnection();
注意:"java:/comp/env/"是固定写法,"jdbc/sqlserver"是数据源的名字。

网上的话:
    数据源:JDBC提供了javax.sql.DataSource的接口,负责与数据库建立连接,实际应用时不需要编写连接数据库代码,直接从数据源获得数据库的连接。Dataource中事先建立了多个数据库连接,这些数据库连接保持在数据库连接池中,当程序访问数据库时,只需要从连接池从取出空闲的连接,访问数据库结束,再将这些连接归还给连接池。DataSource对象由容器(Tomcat)提供,不能使用创建实例的方法来生成 DataSource对象,要采用JAVA的JNDI(Java Nameing and Directory Interface,java命名和目录接口)来获得DataSource对象的引用。(另有一种说法:“其实从技术上来说,数据源连接方式是不需要目录服务的,我们同样可以通过序列化数据源对象直接访问文件系统。这点是需要明确的。”感兴趣的朋友可以试试。)JNDI是一种将对象和名字绑定的技术,对象工厂负责生产出对象,这些对象都和唯一的名字相绑定。程序中可以通过这个名字来获得对象的引用。Tomcat把DataSource作为一种可配置的 JNDI资源来处理,生成DataSource对象的工厂为 org.apache.comm.ons.dbcp.BasicDataSourceFactory。

剩下的疑问:
    网上说要配置一个DataSource对象的工厂,但是我没配置也能查找数据库。为啥?
    "java:/comp/env/"为什么一定要这样写?
    web.xml中的内容好像可以不加,为啥?
望各种大虾不吝赐教,谢谢!!

热点排行