数据源与连接池

1、JNDI Java Naming and Directory Interface
Java命名和目录服务接口
通过一个字符串就能找到指定的资源

JNDI规范通常提供一个lookup方法通过资源字符串查找所指定的资源

2、DataSource
通过一定的配置信息告诉WEB容器,应用连接到哪个数据源

3、配置数据源和数据连接池
1)在tomcat的conf目录下的context.xml文件中增加资源描述标记

<Resource name="jndi/datasource" 数据连接池资源的名称
auth="Container" 认证类型,由容器提供认证
type="javax.sql.DataSource" 表示此资源的类型是什么,javax.sql.DataSource表示为jdbc的数据源类型
driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
url="jdbc:sqlserver://localhost:1433;DatabaseName=MyWEB"
username="sa"
password="12345"
maxTotal="20" 最大连接数
maxIdle="5" 最大空闲连接数
maxWaitMillis="10000"/> 最大等待时间 

 

说明:对tomcat5.0的配置,请参考PPT,<ResourceParams>标记单独配置参数信息
对6.0及以上的tomcat,只需要使用<Resource>标记,把相关的参数配置直接放在该标记的属性部分
对5.0, 6.0, 7.0来说,最大连接数是maxActive,最大等待时间是maxWait(ms)
对8.0来说,最大连接数是maxTotal,最大等待时间 maxWaitMillis
2)在应用的web.xml文件中声明引用了哪个资源

<resource-ref>
<description>JNDI JDBC DataSource </description>
<res-ref-name>jndi/datasource</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>

 

3)使用Context去获取配置的jndi资源

javax.naming.Context context = new javax.naming.InitialContext();
Object obj = context.lookup("java:comp/env/jndi/datasource");
javax.sql.DataSource ds = (javax.sql.DataSource) obj;
javax.sql.Connection conn = ds.getConnection();

 

4、数据库连接池对数据库相关对象的关闭操作
rs.close(), conn.close();
以上的关闭操作,是交由Tomcat容器来做的,conn.close()并没有真正把建立好的数据库连接关闭,而是把此数据库连接放回数据库连接池

5、补充,如果想让eclipse直接使用数据连接池的方式运行应用,则把context.xml文件copy到WebContent目录下的META-INF目录 -+

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值