数据池允许应用程序重复使用一个现有的数据库连接,而不是重新建立一个。这项技术能明显地提高对数据库操作的性能。
数据库连接池在初始化时将创建一定数量的数据库连接,具体数量的由连接池的最小数据库连接数来设定。无论这些数据库是否被使用,连接池都将确保至少拥有这些数量的连接。同时,连接池可以根据池中连接的使用率,动态增加或减少池中的连接数。Java程序访问数据库时,只需从连接池中取出空闲状态的数据库连接,当程序访问数据库结束时,再将数据库连接返回给连接池,这样做可以提高访问数据库的效率。
已经创建但尚未分配出去的连接被存放到一个空闲池中,每当用户请求一个链接时,系统首先检查空闲池内有没有空闲连接。如果有就分配一个连接给用户;如果没有则检查当前连接池是否已达到所允许的最大连接数(连接池的最大数据库连接数量限制了这个连接池能占有的最大连接数),如果没有达到,就新建一个连接。如果已经达到,这些请求将被加入等待列队中。如果在等待的时间内有连接被释放出来,就可以把这个连接分配给等待的用户。需要注意的是,系统对已经分配出去正在使用的连接只做计数,当使用完后,应释放连接并返还给空闲池。
数据源(Data Source)是在JDBC2.0中引入的一个概念。在JDBC扩展包中定义了javax.sql.DataSource接口,它定义了一组特性,用于确定和描述它所表示的现实存在的数据源,配置好的数据库连接池也以DataSource的形式存在。其中现类负责与数据库建立连接,创建连接对象,这些数据库连接保存在连接池中。在应用程序中访问数据库时不必编写连接数据库的代码,可以直接从数据源获得数据库连接。
Tomcat把数据源作为一种可配置的JNDI资源来处理,DataSouce对象由Web容器(Tomcat)提供。在Tomcat环境中,如果发布一个数据源实例,那么Web应用可以通过JNDI进行访问,通过该数据源实例为Web应用提供数据库连接池机制,从而简化Web应用的数据库连接管理问题。
以Tomcat为例,实现数据源的配置和使用,
在本地Tomcat的配置文件中的context.xml文件中添加
属性 | 说明 |
---|---|
name | 指定资源的JNDI名字 |
auth | 指定管理资源的Manager,他有Container和Application两个可选值。Container表示由容器创建Resource,Application表示由Web应用创建和管理Resource |
type | 指定资源所属的java类型 |
maxTotal | 可同时从连接池分配的最大连接数。默认值为8,设置为负数表示不受限制 |
maxIdle | 同时在连接池中处于空闲状态的最大连接数,默认值为8,设置为负数表示不受限制 |
minIdle | 同时在连接池中处于空闲状态的最小连接数,默认值为0 |
maxWaitMillis | 当连接池没有可用连接时,等待获取连接的最大毫秒数,如果超出这一时间将会抛出异常,默认值为-1,表示可以无限等待 |
username | 指定连接数据库的用户名 |
password | 指定连接数据库的口令(密码) |
driverClassName | 指定连接数据库的JDBC驱动程序 |
url | 指定连接数据库的URL |
提示:不同的web服务器设置数据源的方法也是不一样的,应根据服务器提供的帮助文档进行配置
在java web应用的web.xml文件中,为
Microblog DataSource jdbc/Mysql javax.sql.DataSource Container
这里,
属性 | 说明 |
---|---|
description | 对引用资源的说明 |
res-ref-name | 指定所引用资源的JNDI名字,与 |
res-type | 指定所引用资源的Java类型,与 |
res-auth | 指定管理所引用资源的Manager,与 |
要通过数据源访问数据库,还要添加数据库驱动文件。由于数据源由Tomcat创建并维护,所以要把数据库驱动文件放到Tomcat的lib目录下,也可以放到项目中web/WEB-INF/lib下,并添加为库。
然后在连接数据库方法中:
//在用JNDI连接数据库时用main函数测试时总报错, //InitialContext 是要在应用服务器的上下文里才有的。 //在普通的应用程序里是不行的! //要放到tomcat里面运行! //不能用main函数直接测试,只能放到tomcat或者servlet、jsp显示 Context ctx=new InitialContext(); //后面的jdb/Mysql是Context文件里配置的信息 DataSource ds=(DataSource) ctx.lookup("java:comp/env/jdbc/Mysql"); Connection conn=ds.getConnection();
写入上面代码就连接完成了。