数据库连接池


Posted in MySQL onApril 06, 2021

数据库连接池

普通的连接方式不停的连接和断开会消耗大量的资源和时间,没有对资源进行很好的重复利用,不能控制被创建的连接对象数。并且每一次使用完都必须断开,否则如果程序出现异常而未能关闭,将会导致数据库系统的内存泄漏最终重启数据库。

数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”。用时则取,完时则还。数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是重新建立一个。

多种开源的数据库连接池:

JDBC的数据库连接池使用javax.sql.DataSource来表示,DataSource只是一个接口,改接口通常由(Weblogic,WebSphere,Tomcat)提供实现,也有一些开源组织提供实现:

  • DBCP是Apache提供的数据库连接池。Tomcat服务器自带dbcp数据库连接池。速度相对于C3P0较快,但因自身存在BUG,Hibernate3已不再提供支持。
  • C3P0是一个开源组织提供的一个数据库连接池,速度相对较慢,但是稳定性不错。hibernate官方推荐使用。
  • Proxool是sourceforge下的一个开源项目数据库连接池,有监控连接池状态的功能,稳定性较C3P0差一点。
  • BoneCP是一个开源组织提供的数据库连接池,速度快。
  • Druid是阿里提供的数据库连接池。

在这里我们只看Druid,它是阿里巴巴开源平台上一个数据库连接池实现,结合了C3P0、DBCP、Proxool等DB池的优点,同时加入了日志监控,可以很好的监控DB池连接和SQL的执行情况,可以说是针对监控而生的DB连接池,也可以说是目前最好的连接池之一。

首先将驱动配置好

数据库连接池

连接方式一:硬编码,不推荐

import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.pool.DruidPooledConnection;

import java.sql.SQLException;

public class DruidTest {
    public static void main(String[] args) throws SQLException {
        DruidDataSource dds = new DruidDataSource();
        dds.setDriverClassName("com.mysql.jdbc.Driver");
        dds.setUrl("jdbc:mysql://localhost:3306/test");
        dds.setUsername("root");
        dds.setPassword("root");

        DruidPooledConnection c = dds.getConnection();
        System.out.println(c);
    }
}

执行结果:红色是提示信息,不是报错。

数据库连接池

连接方式二:配置文件,推荐

配置参数(常用):

配置 缺省 说明
name   配置这个属性的意义在于,如果存在多个数据源,监控的时候可以通过名字来区分开来。 如果没有配置,将会生成一个名字,格式是:”DataSource-” + System.identityHashCode(this)
url   连接数据库的url,不同数据库不一样。例如:mysql : jdbc:mysql://10.20.153.104:3306/druid2 oracle : jdbc:oracle:thin:@10.20.149.85:1521:ocnauto
username   连接数据库的用户名
password   连接数据库的密码。如果你不希望密码直接写在配置文件中,可以使用ConfigFilter。
driverClassName   根据url自动识别 这一项可配可不配,如果不配置druid会根据url自动识别dbType,然后选择相应的driverClassName(建议配置下)
initialSize 0 初始化时建立物理连接的个数。初始化发生在显示调用init方法,或者第一次getConnection时
maxActive 8 最大连接池数量
maxIdle 8 已经不再使用,配置了也没效果
minIdle   最小连接池数量
maxWait   获取连接时最大等待时间,单位毫秒。配置了maxWait之后,缺省启用公平锁,并发效率会有所下降,如果需要可以通过配置useUnfairLock属性为true使用非公平锁。
poolPreparedStatements false 是否缓存preparedStatement,也就是PSCache。PSCache对支持游标的数据库性能提升巨大,比如说oracle。在mysql下建议关闭。
maxOpenPreparedStatements -1 要启用PSCache,必须配置大于0,当大于0时,poolPreparedStatements自动触发修改为true。在Druid中,不会存在Oracle下PSCache占用内存过多的问题,可以把这个数值配置大一些,比如说100
validationQuery   用来检测连接是否有效的sql,要求是一个查询语句。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会其作用。
testOnBorrow true 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
testOnReturn false 归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能
testWhileIdle false 建议配置为true,不影响性能,并且保证安全性。申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。
timeBetweenEvictionRunsMillis   有两个含义: 1)Destroy线程会检测连接的间隔时间2)testWhileIdle的判断依据,详细看testWhileIdle属性的说明
numTestsPerEvictionRun   不再使用,一个DruidDataSource只支持一个EvictionRun
minEvictableIdleTimeMillis    
connectionInitSqls   物理连接初始化的时候执行的sql
exceptionSorter   根据dbType自动识别 当数据库抛出一些不可恢复的异常时,抛弃连接
filters   属性类型是字符串,通过别名的方式配置扩展插件,常用的插件有: 监控统计用的filter:stat日志用的filter:log4j防御sql注入的filter:wall
proxyFilters   类型是List,如果同时配置了filters和proxyFilters,是组合关系,并非替换关系

第一步:创建properties配置文件

url=jdbc:mysql://localhost:3306/test
username=root
password=root
driverClassName=com.mysql.jdbc.Driver

注:根据自己的需求可以写自己需要的配置,但上边这四个基本信息是必须要有的。

第二步:获取连接

import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.sql.DataSource;
import java.io.InputStream;
import java.sql.Connection;
import java.util.Properties;

public class DruidTest2 {
    public static void main(String[] args) throws Exception {
        Properties p = new Properties();
        InputStream is = ClassLoader.getSystemResourceAsStream("druid.properties");
        p.load(is);
        DataSource ds = DruidDataSourceFactory.createDataSource(p);
        Connection c = ds.getConnection();
        System.out.println(c);
    }
}
MySQL 相关文章推荐
Mysql数据库命令大全
May 26 MySQL
Mysql中 unique列插入重复值该怎么解决呢
May 26 MySQL
Unity连接MySQL并读取表格数据的实现代码
Jun 20 MySQL
SQL实现LeetCode(196.删除重复邮箱)
Aug 07 MySQL
MySQL into_Mysql中replace与replace into用法案例详解
Sep 14 MySQL
MySQL图形化管理工具Navicat安装步骤
Dec 04 MySQL
MySQL的InnoDB存储引擎的数据页结构详解
Mar 03 MySQL
简单聊一聊SQL注入及防止SQL注入
Mar 23 MySQL
使用Mysql计算地址的经纬度距离和实时位置信息
Apr 29 MySQL
Mysql中@和@@符号的详细使用指南
Jun 05 MySQL
MySQL提升大量数据查询效率的优化神器
Jul 07 MySQL
MySQL下载安装配置详细教程 附下载资源
Sep 23 MySQL
mysql优化
Apr 06 #MySQL
Windows10下安装MySQL8
Mysql 如何批量插入数据
Apr 06 #MySQL
MySQL之DML语言
Apr 05 #MySQL
多属性、多分类MySQL模式设计
Apr 05 #MySQL
多表查询、事务、DCL
Mysql Show Profile
Apr 05 #MySQL
You might like
上海地方志办公室-上海电子仪表工业志
2021/03/04 无线电
Yii框架在页面输出执行sql语句以方便调试的实现方法
2014/12/24 PHP
javascript Excel操作知识点
2009/04/24 Javascript
jquery仿京东导航/仿淘宝商城左侧分类导航下拉菜单效果
2013/04/24 Javascript
Javascript实现动态菜单添加的实例代码
2013/07/05 Javascript
JS实现多物体缓冲运动实例代码
2013/11/29 Javascript
Javascript核心读书有感之表达式和运算符
2015/02/11 Javascript
javascript遇到html5的一些表单属性
2015/07/05 Javascript
JavaScript实现获得所有兄弟节点的方法
2015/07/23 Javascript
JavaScript File API实现文件上传预览
2016/02/02 Javascript
javascript获取select标签选中的值
2016/06/04 Javascript
完美解决jQuery fancybox ie 无法显示关闭按钮的问题
2016/11/29 Javascript
bootstrap模态框跳转到当前模板页面 框消失了而背景存在问题的解决方法
2020/11/30 Javascript
jQuery基于Ajax方式提交表单功能示例
2017/02/10 Javascript
详解Node.js串行化流程控制
2017/05/04 Javascript
基于JavaScript实现百度搜索框效果
2020/06/28 Javascript
Vue内容分发slot(全面解析)
2017/08/19 Javascript
一步快速解决微信小程序中textarea层级太高遮挡其他组件
2019/03/04 Javascript
Node.js动手撸一个静态资源服务器的方法
2019/03/09 Javascript
操作按钮悬浮固定在微信小程序底部的实现代码
2019/08/02 Javascript
vue中如何实现后台管理系统的权限控制的方法步骤
2019/09/05 Javascript
js实现简易计算器功能
2019/10/18 Javascript
深入浅析Python 中的sklearn模型选择
2019/10/12 Python
Python中类似于jquery的pyquery库用法分析
2019/12/02 Python
深入理解Tensorflow中的masking和padding
2020/02/24 Python
Python json格式化打印实现过程解析
2020/07/21 Python
八年级物理教学反思
2014/01/19 职场文书
生日礼品店创业计划书范文
2014/03/21 职场文书
导师推荐信范文
2014/05/09 职场文书
商务英语专业求职信
2014/06/26 职场文书
2014大学生中国梦主题教育学习思想汇报
2014/09/10 职场文书
教师个人事迹材料
2014/12/17 职场文书
《乌鸦喝水》教学反思
2016/02/19 职场文书
2016秋季运动会开幕词
2016/03/04 职场文书
Java使用jmeter进行压力测试
2021/07/09 Java/Android
GoFrame gredis缓存DoVar Conn连接对象 自动序列化GoFrame gredisDo/DoVar方法Conn连接对象自动序列化/反序列化总结
2022/06/14 Golang