博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java数据库连接池
阅读量:5159 次
发布时间:2019-06-13

本文共 1177 字,大约阅读时间需要 3 分钟。

    当你的网站访问量很大的时候,数据库服务器在每一次连接时创建一次数据库连接,这样就浪费了很多的数据库资源,并且容易造成该数据库服务器内存溢出。数据库作为网站的核心模块,它的性能影响到了战歌网站的性能,数据库连接池可以解决这个问题:数据库连接池负责分配,管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是新建立一个。

 

import java.sql.Connection;import java.util.LinkedList;import com.heima.utils.JdbcUtils;public class MyConnectionPool{    //创建一个连接池  private static LinkedList
pool = 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关键字,用来修饰一个方法或者一个代码块的时候,能够保证同一时刻最多只有一个线程执行该代码块。

转载于:https://www.cnblogs.com/taiguyiba/p/6112415.html

你可能感兴趣的文章
[转载]mysql的left,right,substr,instr截取字符串,截取
查看>>
Visual Studio自定义模板(二)
查看>>
【Mood-20】滴滤咖啡做法 IT工程师加班必备 更健康的coffee 项目经理加班密鉴
查看>>
摘抄详细的VUE生命周期
查看>>
javascript高级程序设计---js事件思维导图
查看>>
sprint计划会议
查看>>
读《构建之法-软件工程》第四章有感
查看>>
使用 Printf via SWO/SWV 输出调试信息
查看>>
.net 分布式架构之分布式锁实现(转)
查看>>
吴恩达机器学习笔记 —— 3 线性回归回顾
查看>>
在SpringMVC中自定义上下文的一些想法
查看>>
在libGDX中使用Spine骨骼动画
查看>>
Windows防火墙开启ping,禁ping的配置方法
查看>>
Android studio打开之后 cannot load project: java.lang.NUllpointerException
查看>>
环境搭建
查看>>
win10 下 protobuf 与 qt
查看>>
在Linux中设置共享目录
查看>>
随笔记
查看>>
零基础逆向工程16_C语言10_宏定义_头文件_内存分配_文件读写
查看>>
Map,HashMap,LinkedHashMap,TreeMap比较和理解
查看>>