Java数据库连接池之DBCP浅析_动力节点Java学院整理-创新互联

一. 为何要使用数据库连接池

创新互联专注于临沧企业网站建设,成都响应式网站建设,商城网站建设。临沧网站建设公司,为临沧等地区提供建站服务。全流程按需开发,专业设计,全程项目跟踪,创新互联专业和态度为您提供的服务

假设网站一天有很大的访问量,数据库服务器就需要为每次连接创建一次数据库连接,极大的浪费数据库的资源,并且极易造成数据库服务器内存溢出、拓机。


数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现的尤为突出.对数据库连接的管理能显著影响到整个应用程序的伸缩性和健壮性,影响到程序的性能指标.数据库连接池正式针对这个问题提出来的.数据库连接池负责分配,管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是重新建立一个。

数据库连接池在初始化时将创建一定数量的数据库连接放到连接池中, 这些数据库连接的数量是由最小数据库连接数来设定的.无论这些数据库连接是否被使用,连接池都将一直保证至少拥有这么多的连接数量.连接池的大数据库连接数量限定了这个连接池能占有的大连接数,当应用程序向连接池请求的连接数超过大连接数量时,这些请求将被加入到等待队列中.

数据库连接池的最小连接数和大连接数的设置要考虑到以下几个因素:

  1, 最小连接数:是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费.
  2, 大连接数:是连接池能申请的大连接数,如果数据库连接请求超过次数,后面的数据库连接请求将被加入到等待队列中,这会影响以后的数据库操作
  3, 如果最小连接数与大连接数相差很大:那么最先连接请求将会获利,之后超过最小连接数量的连接请求等价于建立一个新的数据库连接.不过,这些大于最小连接数的数据库连接在使用完不会马上被释放,他将被           放到连接池中等待重复使用或是空间超时后被释放.

二, 数据库连接池的原理及实现

到了这里我们已经知道数据库连接池是用来做什么的了, 下面我们就来说数据库连接池是如何来实现的.
1, 建立一个数据库连接池pool, 池中有若干个Connection 对象, 当用户发来请求需要进行数据库交互时则会使用池中第一个Connection对象.
2, 当本次连接结束时, 再将这个Connection对象归还池中, 这样就可以保证池中一直有足够的Connection对象.

public class SimplePoolDemo {
 //创建一个连接池
 private static LinkedList pool = new LinkedList(); 
 
 //初始化10个连接
 static{
  try {
   for (int i = 0; i < 10; i++) {
    Connection conn = DBUtils.getConnection();//得到一个连接
    pool.add(conn);
   }
  } catch (Exception e) {
   throw new ExceptionInInitializerError("数据库连接失败,请检查配置");
  }
 }
 //从池中获取一个连接
 public static Connection getConnectionFromPool(){
  return pool.removeFirst();//移除一个连接对象
 }
 //释放资源
 public static void release(Connection conn){
  pool.addLast(conn);
 }
}

当前题目:Java数据库连接池之DBCP浅析_动力节点Java学院整理-创新互联
浏览地址:http://abwzjs.com/article/jigid.html