Java数据库连接池
当你的网站访问量很大的时候,数据库服务器在每一次连接时创建一次数据库连接,这样就浪费了很多的数据库资源,并且容易造成该数据库服务器内存溢出。数据库作为网站的核心模块,它的性能影响到了战歌网站的性能,数据库连接池可以解决这个问题:数据库连接池负责分配,管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是新建立一个。
import java.sql.Connection; import java.util.LinkedList;import com.heima.utils.JdbcUtils;
public class MyConnectionPool{
// 创建一个连接池
private static LinkedList<Connection> pool = new LinkedList<Connection>() ;
// 初始化 10 个连接池
static{
for (int i = 0; i < 10; i++) {
Connection conn = JdbcUtils.getConnection() ; // 得到一个连接
pool.add(conn) ;
}
}
// 从池中获取一个连接
public synchronized static Connection getConnection(){
if(pool.size() > 0)
return pool.removeFirst() ; // 移除一个连接
else
throw new RuntimeException("对不起,服务器忙") ;
}
// 释放资源
public static void close(Connection conn){
if(conn != null)
pool.addLast(conn) ; //放回池中
}
}
LinkedList<E> List 接口的链接列表实现。实现所有可选的操作,,并且允许所有元素(包括 null)。除了实现 List 接口外,还为在列表的开头及结尾 get,remove 和 insert 元素提供了同意的命名方法。这些操作允许将链接列表用作堆栈、队列或双端队列。
注意:此实现不是同步的。
synchronized : java 关键字,用来修饰一个方法或者一个代码块的时候,能够保证同一时刻最多只有一个线程执行该代码块。