JAVA_java数据库连接池
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
JAVA数据库连接池
●基本概念及原理
⏹数据库连接池是为了解决数据库对象
的共享出错问题。
⏹实际就是建立一个缓冲池。
⏹原理
预先在缓冲池中放入一定数量的连接,
当需要建立数据库连接时,只需从连接
池中取出一个,使用完毕之后再放回
去。
⏹JDBC的API中没有提供连接池的方法。
●连接池关键问题分析
⏹使用线程同步来解决并发问题
⏹使用一个单例模式的连接池管理类来
解决连接多个不同数据库。具体方法:
◆在连接池管理类的唯一实例被创建
时读取一个资源文件,其中资源文件
中存放着多个数据库的url地址()、
用户名()、密码()等信息。如
tx.url=172.21.15.123:
5000/tx_it,er=yang,
tx.password=yang321。
◆根据资源文件提供的信息,创建多
个连接池类的实例,每一个实例都是
一个特定数据库的连接池。连接池管
理类实例为每个连接池实例取一个
名字,通过不同的名字来管理不同的
连接池。
⏹使用资源文件来解决同一个数据库有多个用户使用不同的名称和密码访问的情况。具体方法:
◆资源文件中设置多个具有相同url
地址,但具有不同用户名和密码的数
据库连接信息。
⏹可采用每一个事务独占一个连接来实现事务处理, 这种方法可以大大降低事务管理的复杂性。具体方法:
◆Connection类可以通过设置
Connection的AutoCommit属性为
false,然后显式的调用commit或
rollback方法来实现。
⏹使用空闲池来解决连接池的分配与释放处理。具体办法:
◆把已经创建但尚未分配出去的连接按创建时间存放到一个空闲池中。
◆每当用户请求一个连接时,系统首先检查空闲池内有没有空闲连接:●如果有就把建立时间最长(通过容
器的顺序存放实现)的那个连接分
配给他(实际是先做连接是否有效
的判断,如果可用就分配给用户,
如不可用就把这个连接从空闲池删
掉,重新检测空闲池是否还有连
接)。
●如果没有则检查当前所建连接池是
否达到连接池所允许的最大连接数
(maxConn),如果没有达到,就新建
一个连接,如果已经达到,就等待
一定的时间(timeout)。如果在等
待的时间内有连接被释放出来就可
以把这个连接分配给等待的用户,
如果等待时间超过预定时间
timeout,则返回空值(null)。
◆系统对已经分配出去正在使用的连
接只做计数,当使用完后再返还给空
闲池。
⏹连接池的配置与维护
◆连接池中到底应该放置多少连接,
才能使系统的性能最佳?
●设置连接最小数(系统启动时连接
池所创建的连接数)、最大数(使用
连接池时所允许连接最大连接数
目)
◆如何确保连接池中的最小连接数
呢?
●动态策略: 每隔一定时间就对连
接池进行检测,如果发现连接数量
小于最小连接数,则补充相应数量
的新连接,以保证连接池的正常运
转。
●静态策略: 发现空闲连接不够时
再去检查。
●连接池的实现
⏹连接池模型
◆DBConnectionPoolManager(
连接池管理外覆类(wrapper),符合单例模式)
●
◆DBConnectionPool(连接池内部类)
●从连接池获取或创建可用连接;
public Connection getConnection()
●使用完毕之后,把连接返还给连接
池;
public synchronized void freeConnection(Connection con) ●在系统关闭前,断开所有连接并释
放连接占用的系统资源;
public synchronized void release()
●还能够处理无效连接(原来登记为
可用的连接,由于某种原因不再可
用,如超时,通讯问题),并能够
限制连接池中的连接总数不低于某
个预定值和不超过某个预定值。
private int checkedOut;//已被分配出去的连接数
private int minConn;//连接池里连接的最小数量
private int maxConn;//连接池里允许存在的最大连接数
private String name; //为这个连接池取个名字,方便管理
应用示例: