当你的网站访问量很大的时候,数据库服务器在每一次连接时创建一次数据库连接,这样就浪费了很多的数据库资源,并且容易造成该数据库服务器内存溢出。数据库作为网站的核心模块,它的性能影响到了战歌网站的性能,数据库连接池可以解决这个问题:数据库连接池负责分配,管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是新建立一个。
import java.sql.Connection;import java.util.LinkedList;import com.heima.utils.JdbcUtils;public class MyConnectionPool{ //创建一个连接池 private static LinkedListpool = new LinkedList () ; //初始化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关键字,用来修饰一个方法或者一个代码块的时候,能够保证同一时刻最多只有一个线程执行该代码块。