当前位置: 首页 > news >正文

数据访问层设计_6.连接对象管理设计

1.数据库连接管理 

        在基于JDBC的数据库应用开发中,数据库连接的管理是一个难点,因为它是决定该应用性能的一个重要因素。

        对于共享资源,有一个很著名的设计模式——资源池。该模式正是为了解决资源频繁分配、释放所造成的问题。把该模式应用到数据库连接管理领域,就是建立一个数据库连接池,提供一套高效的连接分配、使用策略。

2.静态的连接池

        建立连接池的第一步,就是要建立一个静态的连接池。所谓静态,是指池中的连接是在系统初始化时就分配好的,并且不能够随意关闭。Java中给我们提供了很多容器类,可以方便地用来构建连接池,如Vector、Stack等。在系统初始化时,根据配置创建连接并放置在连接池中,以后所使用的连接都是从该连接池中获取的,这样就可以避免连接随意建立、关闭造成的开销(当然,我们没有办法避免Java的Garbage Collection带来的开销)。

3.分配释放策略 

        有了这个连接池,下面就可以提供一套自定义的分配、释放策略。当客户请求数据库连接时,首先看连接池中是否有未分配出去的连接。如果存在空闲连接则把连接分配给客户,并作相应处理。具体处理策略,在关键议题中会详述,主要的处理策略就是标记该连接为已分配。若连接池中没有空闲连接,就在已经分配出去的连接中,寻找一个合适的连接给客户,此时该连接在多个客户间复用。

        当客户释放数据库连接时,可以根据该连接是否被复用,进行不同的处理。如果连接没有使用者,就放入到连接池中,而不是被关闭。

        可以看出,正是这套策略保证了数据库连接的有效复用。

4.数据库连接池示例

4.1数据库连接池示意图 

        1) 预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕后放回去。
        2) 数据库连接池负责分配、管理和释放数据库连接,它允许程序重复使用一个现有连接,而不是重新建立一个。
        3) 当应用程序连接向连接池请求数量超过最大数量时,这些请求将被加入到等待队列。

        当连接池中连接都用完时,会进入等待队列,等待再连接。放回连接是不在引用连接,而不是断掉连接到数据库的线。 

 4.2数据库连接池种类

        开源的免费连接池:

        DBCP  C3P0  Proxool  Druid  Jakarta  DDConnectionBroker  BoneCP

       XAPool  Primrose  SmartPool  MiniConnectionPoolManager 

        商业的中间件连接池:

        weblogic的连接池   websphere的连接池

相关文章:

  • Jenkins升级到2.458后publish over ssh报错
  • 基于深度学习的表情识别系统
  • 运行时间比较
  • Qt | QCalendarWidget 类(日历)
  • Qml:键盘事件
  • gpt-4o考场安排
  • Spring Cloud 框架的应用详解
  • 深入Django项目实战与最佳实践
  • npm install [Error]
  • 汉语拼音 如何 转化成粤语拼音 的
  • 轻量音乐网站程序源码,在线音乐免费听歌
  • Qt 科目一考试系统(有源码)
  • CTF网络安全大赛简单web题目:eval
  • el-upload上传图片,视频可获取视频时长。
  • c++/c语法基础【2】
  • 【刷算法】求1+2+3+...+n
  • 【跃迁之路】【699天】程序员高效学习方法论探索系列(实验阶段456-2019.1.19)...
  • 08.Android之View事件问题
  • 4个实用的微服务测试策略
  • IDEA 插件开发入门教程
  • Intervention/image 图片处理扩展包的安装和使用
  • Java基本数据类型之Number
  • Java应用性能调优
  • nodejs调试方法
  • PHP面试之三:MySQL数据库
  • spring学习第二天
  • Vue ES6 Jade Scss Webpack Gulp
  • 阿里云应用高可用服务公测发布
  • 测试如何在敏捷团队中工作?
  • 成为一名优秀的Developer的书单
  • 发布国内首个无服务器容器服务,运维效率从未如此高效
  • 基于阿里云移动推送的移动应用推送模式最佳实践
  • 记一次和乔布斯合作最难忘的经历
  • 经典排序算法及其 Java 实现
  • 前端每日实战 2018 年 7 月份项目汇总(共 29 个项目)
  • 融云开发漫谈:你是否了解Go语言并发编程的第一要义?
  • 使用Envoy 作Sidecar Proxy的微服务模式-4.Prometheus的指标收集
  • 一个SAP顾问在美国的这些年
  • 怎样选择前端框架
  • 栈实现走出迷宫(C++)
  • - 转 Ext2.0 form使用实例
  • 测评:对于写作的人来说,Markdown是你最好的朋友 ...
  • ​​​​​​​ubuntu16.04 fastreid训练过程
  • #100天计划# 2013年9月29日
  • #LLM入门|Prompt#2.3_对查询任务进行分类|意图分析_Classification
  • #单片机(TB6600驱动42步进电机)
  • (11)工业界推荐系统-小红书推荐场景及内部实践【粗排三塔模型】
  • (4)(4.6) Triducer
  • (9)STL算法之逆转旋转
  • (Java)【深基9.例1】选举学生会
  • (TOJ2804)Even? Odd?
  • (二)c52学习之旅-简单了解单片机
  • (十七)Flask之大型项目目录结构示例【二扣蓝图】
  • (四)Tiki-taka算法(TTA)求解无人机三维路径规划研究(MATLAB)
  • .form文件_一篇文章学会文件上传