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中的内容好像可以不加,为啥?
望各种大虾不吝赐教,谢谢!!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值