数据源与连接池

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目录 -+

原文地址:https://www.cnblogs.com/A0926/p/5443820.html