Java开发笔记(一百五十一)Druid连接池的用法

C3P0连接池自诞生以来在Java Web领域反响甚好,业已成为hibenate框架推荐的连接池。谁知人红是非多,C3P0在大型应用场合中暴露了越来越多的局限性,包括但不限于下列几点:
1、C3P0管理池内连接时没有采取LRU排队规则(最久未使用算法),意味着C3P0未能将数据库性能调到最优。
2、在处理大批量数据的时候,C3P0对耗时操作过于容忍,致使容易出现线程死锁的状况。
3、C3P0不支持监控功能,外界难以实时跟踪连接池的运行情况,不利于按需分配和调度系统资源。
就上面几点问题的看法因人而异,对老外来说,他们国家人口不多,一百年都难得遇上这种严苛的条件,考虑超大规模的数据处理纯属杞人忧天。但对国人来说,数据库里的业务记录动辄以千万计,亿级以上的海量数据也不罕见,此时一点一滴的性能差距汇总起来就可能出大问题。然而C3P0源自国外,人家才懒得搭理这茬事;再说,此等关键要害岂能由外人扼住咽喉?当然要自己掌握核心技术才让人放心,于是阿里巴巴公司推出了国产的开源连接池Druid,该连接池立足于本国国情,在诸多方面加以调整和优化,比C3P0更适用于国内的业务系统。
Druid的用法近似于C3P0,它拥有自己的连接池工具DruidDataSource,该工具的常见方法列举如下:
setDriverClassName:设置连接池的数据库驱动。
setUrl:设置数据库的连接地址。
setUsername:设置数据库的用户名。
setPassword:设置数据库的密码。
setInitialSize:设置连接池的初始大小。
setMinIdle:设置连接池大小的下限。
setMaxActive:设置连接池大小的上限。
setRemoveAbandoned:设置是否抛弃已超时的连接。
setRemoveAbandonedTimeout:设置超时的时间间隔,单位秒。如果某连接超过该时间仍未释放,则会被自动回收。
setMaxWait:设置获取连接所允许的等待时间,单位毫秒。超过该时间将不再获取连接。
setTimeBetweenEvictionRunsMillis:设置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位毫秒。
setValidationQuery:设置检测连接是否有效的SQL语句。
setTestWhileIdle:当空闲时是否需要进行有效性测试。建议设置为true,保证安全性。
setTestOnBorrow:设置为true,表示申请连接时将调用validationQuery方法来检测连接是否有效。
getDbType:获取数据库的名称。
getActiveCount:获取活跃连接的数量。
getConnectCount:获取已连上连接的数量。
getPoolingCount:获取空闲连接的数量。
getConnection:从连接池中获取一个连接,连接类型为DruidPooledConnection。
close:关闭连接池。

至于Druid的编码过程,则依然分成两个步骤:初始化连接池、从连接池中取出一个连接处理,分别说明如下:
1、初始化连接池
该步骤首先创建Druid连接池的对象,再依次调用相关方法设置详细的参数信息,包括数据库驱动、连接地址、用户名、密码,以及与连接池有关的规格参数。下面是初始化Druid连接池的代码例子:

2、从连接池中取出一个连接处理
注意该步骤的getConnection方法拿到的是DruidPooledConnection类型的连接对象,再根据该连接创建对应的报告,并开展后续的数据库操作。为方便观察连接池的运行情况,可在其中添加几个连接池的检测方法,例如getActiveCount、getConnectCount、getPoolingCount等等。修改后的数据库操作代码示例如下:

然后由外部反复调用以上的showRecordGroupBySex方法,假设准备测试连续的三次数据库操作,则外部的调用代码如下所示:

运行包含上面代码的测试程序,观察到下面的输出日志:

由日志可见,getActiveCount方法返回了当前正在使用的连接数量,getConnectCount方法返回了曾经连上与已经连上的连接总数,getPoolingCount返回了连接池中剩余的连接数量。

Original: https://www.cnblogs.com/pinlantu/p/11544703.html
Author: pinlantu
Title: Java开发笔记(一百五十一)Druid连接池的用法

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/574375/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • Linux下安装Redis

    redis5.0.7Linux下安装包网盘地址: 链接:https://pan.baidu.com/s/1n2GV8tye18SiugNGWg1otg提取码:gy2s 1.解压re…

    Java 2023年6月8日
    069
  • springboot 读取配置信息

    Spring Boot可以通过 @PropertySource, @Value, @Environment, @ConfigurationProperties 来绑定变量 1.读取…

    Java 2023年5月30日
    058
  • Linux安装Tomcat

    一、下载Tomcat 下载地址:https://tomcat.apache.org/download-80.cgi 二、上传至服务器然后解压 首先确定安装位置,创建文件夹夹。 文件…

    Java 2023年6月8日
    061
  • Mybatis延迟加载

    resultMap中的association和collection标签具有延迟加载的功能。 延迟加载的意思是说,在关联查询时,利用延迟加载,先加载主信息。使用关联信息时再去加载关联…

    Java 2023年6月13日
    061
  • 还在纠结报表工具的选型么?来看看这个

    数据信息化的应用与项目中,通常都会遇到报表需求,数量少的,零星需要做的,可能手工就搞定了,数量多的,长期做的,基本都会选用一个报表工具,因为长期做,就必须考虑成本了,找一个称手的工…

    Java 2023年6月15日
    074
  • linux下weblogic12c漏洞打补丁基本操作

    日常运维工作中我们有时需要给weblogic打补丁,补丁文件是oracle官方发布的zip包。下面均为我本地的目录结构,实际操作中以你实际的目录为准。 1、上传补丁并解压 cd /…

    Java 2023年6月5日
    072
  • 下单流程解耦新方案-你知道Spring事件监听机制吗

    一、Spring事件监听介绍 Spring对事件监听是通过事件类型、事件类型监听和事件发布器3个部分来完成的 // 1. 自定义订单事件 public class OrderEve…

    Java 2023年6月14日
    067
  • TensorFlow安装步骤

    最后命令行提示无错误即为安装成功 posted @2022-09-08 20:55 山海自有归期 阅读(38 ) 评论() 编辑 Original: https://www.cnb…

    Java 2023年6月7日
    072
  • Elasticsearch 入门实战(5)–Java API Client 使用

    本文主要介绍 Elasticsearch Java API Client 的使用,相关的环境及软件信息如下:CentOS 7.6.1810、Java 1.8.0_321(客户端用)…

    Java 2023年6月16日
    071
  • Spring:SpringMVC一例

    文章目录 + [目录结构](#-1) + [web.xml](#webxml-4) + [SpringMVC核心配置文件:md5-servlet.xml](#springmvcmd…

    Java 2023年5月30日
    077
  • Java集合归纳总结

    我们讲集合,就是Collection顶级接口下包括的一些常用集合数据结构,大致分为三类:List(可重复元素集)、Map(KV映射集)、Set(不可重复集)、Queue(队列) 总…

    Java 2023年6月5日
    067
  • JMM(Java内存模型)详解

    1.什么是JMM? 2.JMM的三大特性: * 1.原子性 2.可见性 3.有序性 3.关于同步的规定: 4.解释说明 1.什么是JMM?​ JMM 是Java内存模型( Java…

    Java 2023年5月29日
    0113
  • MongoDB 常用启动参数

    每日一句 Once you choose your way of life, be brave to stick it out and never return. 生活的道路一旦选…

    Java 2023年6月9日
    0176
  • Nginx 同一个服务器设置二级域名

    设置二级域名 首先到域名运营商处设置二级域名使其生效。(已阿里的域名管理为例) 进入解析 添加记录,记录类型为 A;主机记录填写二级域名比如 picture,这样我的二级域名就是 …

    Java 2023年5月30日
    084
  • 【每日算法】动态规划五

    918.环形子数组的最大和 152.乘积最大子数组 1567.乘积为正数的最长子数组长度 难度[中等] 给定一&a…

    Java 2023年6月9日
    060
  • C语言-内存函数的实现(一)之memcpy

    C语言中的内存函数有如下这些 memcpy memmove memcmp memset 下面看看memcpy函数 我们想想,之前有那个字符串拷贝的函数,即strcpy函数。都有拷贝…

    Java 2023年6月10日
    087
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球