数据库连接池的使用

数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个;释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏。这项技术能明显提高对数据库操作的性能。

数据库连接池在初始化时将创建一定数量的数据库连接放到连接池中,这些数据库连接的数量是由最小数据库连接数制约。无论这些数据库连接是否被使用,连接池都将一直保证至少拥有这么多的连接数量。连接池的最大数据库连接数量限定了这个连接池能占有的最大连接数,当应用程序向连接池请求的连接数超过最大连接数量时,这些请求将被加入到等待队列中。数据库连接池的最小连接数和最大连接数的设置要考虑到下列几个因素:
1. 最小连接数
是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费。
2. 最大连接数
是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影响之后的数据库操作。
3. 最小连接数与最大连接数差距
最小连接数与最大连接数相差太大,那么最先的连接请求将会获利,之后超过最小连接数量的连接请求等价于建立一个新的数据库连接。不过,这些大于最小连接数的数据库连接在使用完不会马上被释放,它将被放到连接池中等待重复使用或是空闲超时后被释放。
 
数据库连接池有很多,比如说c3p0,DBPool,阿里的Druid,现在用的比较多的是阿里的Druid。其他数据库连接池的产品也是差不多的使用方式。
注意:使用数据库连接池需要下载相应的mysql-jdbc驱动包和Druid驱动包。

mport com.alibaba.druid.pool.DruidDataSource;
import java.sql.Connection;
import java.sql.SQLException;

public class DruidConnUtil {
private static String URL="jdbc:mysql://10.0.0.11:3306/demo?useUnicode=true&characterEncoding=utf8&useSSL=true";
private static String DRIVER="com.mysql.jdbc.Driver";
private static String USER="root";
private static String PASSWORD="admin.123";
private static DruidDataSource dataSource = new DruidDataSource();
static {
//设置数据库连接地址
dataSource.setUrl(URL);
//设置数据库连接用户名
dataSource.setUsername(USER);
//设置数据库连接密码
dataSource.setPassword(PASSWORD);
//设置数据库连接驱动
dataSource.setDriverClassName(DRIVER);
//设置初始化连接大小
dataSource.setInitialSize(10);
//设置连接池最大链接数量
dataSource.setMaxActive(20);
//获取连接最大等待时间
dataSource.setMaxWait(30000);
}

public static Connection getConnection(){
try {
return dataSource.getConnection();
} catch (Exception e) {
e.printStackTrace();
}
return null;

}
/**
*
* @param conn
* 关闭连接
*/
public static void close(Connection conn){
try {
conn.close();
}
catch (SQLException e) {
e.printStackTrace();
}
}

}

测试连接

package utils;

import java.sql.Connection;

public class Test {

public static void main(String[] args) {
Connection conn = DruidConnUtil.getConnection();
System.err.println(conn);

}

}

 

出现以下结果就是连接成功了!

posted @ 2019-06-05 15:09  凄夜听雨  阅读(293)  评论(0编辑  收藏  举报