数据库连接池即:
初始化多个连接,当需要获取连接,直接从连接池中去取,而不需要经过建立连接,进行操作,关闭连接等一系列操作,当用户量到达一定程度,连接池中的连接被用完时,程序又会自动补充获取固定数量的连接,当用户量减少时,程序会自动关闭多余的连接,直到剩下最后默认初始化的几个连接存在。
java代码简单实现如下:
public class MyPool {
private static Logger log = Logger.getLogger(MyPool.class);
private Configuration configuration;
private int initCount = 10; //初始化连接数量
private int newCount = 10; //新增的数量
private int maxCount = 100; //最大连接数
private int count = 0; //当前总数量
private LinkedList<Connection> pools = new LinkedList(); //池子,用于存放连接
static{
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (ClassNotFoundException e) {
log.error("驱动类没找到,请检查依赖是否正确导入");
e.printStackTrace();
}
}
public MyPool(Configuration configuration) {
try {
log.info("正在初始化连接池,数量为:" + initCount );
this.configuration = configuration;
for (int i = 0; i < initCount; i++) {
Connection connection = createConnection();
log.debug(connection.toString());
count++;
pools.add(connection);
}
}catch (Exception e){
e.printStackTrace();
}
}
/**
* 创建连接
* @return
*/
private Connection createConnection() throws Exception {
if (count>=maxCount) {
throw new Exception("已达到最大连接数");
}
return DriverManager.getConnection(configuration.getUrl(), configuration.getUsername(), configuration.getPassword());
}
/**
* 获取连接
* @return
*/
public Connection getConnection() throws Exception {
log.debug("连接池数量:" + pools.size() + ", 总连接数:" + count);
if (pools.size()<=0) {
//如果池子中没有连接,则创建新连接
for (int i = 0; i < newCount; i++) {
Connection connection = createConnection();
//将创建出来的连接放入池子中
count++;
log.debug("新建连接:" +connection);
pools.add(connection);
}
}
//从池子中获取一个连接
Connection connection = pools.getFirst();
//从池子中移除一个连接,表示该连接已经有人使用了
pools.remove(connection);
return connection;
}
/**
* 关闭连接
* @param connection
*/
public void close(Connection connection){
pools.add(connection);
}
}