阿里巴巴主流数据库连接池Druid入门

阿里巴巴主流数据库连接池Druid入门一.数据库连接池的必要性(一).传统数据库连接模式的的步骤1.在主程序中创建连接2.进行sql操作3.关闭数据库连接(二).传统数据库连接模式存在的问题1.浪费时间:每次连接时都要验证登录和将conn加载到内存,2.不能大规模的访问数据库:当数据库访问人数过多时,占用大量系统资源,会导致服务器崩溃3.存在内存泄漏问题:每次连接都需要断开连接,如果不断开,程序运行结束,会有创建的连接对象存在内存中一直无法关闭,就会导致java内存…

大家好,又见面了,我是你们的朋友全栈君。

阿里巴巴主流数据库连接池Druid入门

目录

一.数据库连接池的必要性

(一).传统数据库连接模式的的步骤

(二).传统数据库连接模式存在的问题

二.数据库连接池技术

(一).数据连接池的思想:

(二).数据库连接池的任务:

(三).数据库连接池的规模:

(四).工作原理:

(五).数据库连接池的优点:

1.资源重用:

2.更快的反应速度:

3.数据库共享机制

4.避免内存泄漏:

三.多种开源的数据库连接池

四.学习最主流的数据库连接池Druid

(一).为druid数据库连接池创建properties文件

(二).创建数据库连接池

(三).测试通过数据库连接池获取连接对象

(四).测试结果(创建成功)

五.Druid数据库连接池常见配置参数


一.数据库连接池的必要性

(一).传统数据库连接模式的的步骤

        1.在主程序中创建连接

        2.进行sql操作

        3.关闭数据库连接

(二).传统数据库连接模式存在的问题

1.浪费时间:每次连接时都要验证登录和将conn加载到内存,

2.不能大规模的访问数据库:当数据库访问人数过多时,占用大量系统资源,会导致服务器崩溃

3.存在内存泄漏问题:每次连接都需要断开连接,如果不断开,程序运行结束,会有创建的连接对象存在内存中一直无法关闭,就会导致java内存泄漏的问题。

内存泄漏:指创建的对象无法被回收

二.数据库连接池技术

(一).数据连接池的思想:

事先在内存中建立一个缓冲池,用来存放一定数量的连接对象,需要时在里面调用,结束时放回缓冲池。

(二).数据库连接池的任务:

管理和释放数据库连接,允许用户使用池内的连接对象,而不需要创建对象。

(三).数据库连接池的规模:

初始化时的数量:由数据库最小连接数来设定;

最大数量:最大数据库连接数来确定。

当连接数超过了最大连接数,超过的连接就会停止等待连接对象的释放。

(四).工作原理:

阿里巴巴主流数据库连接池Druid入门

 (五).数据库连接池的优点:

1.资源重用:

连接池中的对象需要时取出,不需要被连接池回收

2.更快的反应速度:

事先在池中储备连接对象,初始化已经完成,直接调用。

3.数据库共享机制

多个用户访问同一数据库,通过在应用层的配置,可以避免资源独占。

4.避免内存泄漏:

连接对象统一管理,设置连接对象时间片,超时强制回收。

三.多种开源的数据库连接池

JDBC的数据库连接池使用javax.sql.DataSource来表示,DataSource是一个接口,该接口通常由服务器提供

(一).常见的开源数据库连接池:

DBCP:速度比C3P0快但有bug

c3p0:速度慢,但相对稳定

Proxool:开源连接池,有监控连接池的功能,但稳定性比C3P0差

BoneCP:速度快,开源

Druid:阿里提供的连接池,速度快(不及BoneCP),稳定性好,有监控连接池的功能。

阿里巴巴主流数据库连接池Druid入门

四.学习最主流的数据库连接池Druid

(一).为druid数据库连接池创建properties文件

driverClassName=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/jdbc_db
username=root
password=3.141592654
initialSize=10
maxActive=20

(二).创建数据库连接池

public Class JDBCUtils{ 
   private static DataSource source;
    static {
        try{
            //创建properties对象,用来封装从文件中获取的流数据
            Properties pros = new Properties();
            //采用类加载方式获取文件的内容,并封装成流
            InputStream is = ClassLoader.getSystemClassLoader().getResourceAsStream("Druid.properties");
            //将流传入到pros对象中
            pros.load(is);
            //利用工厂类创建数据库连接池
            source = DruidDataSourceFactory.createDataSource(pros);
        }catch (Exception e){
            e.printStackTrace();
        }
    }
    public static Connection getConnByDruid() throws Exception {
        //所有的数据连接池要想被java所使用,都必须先实现sun公司提供的一个接口DateSource
        //获取数据库连接池对象
        Connection conn = source.getConnection();
        return conn;
    }
}

(三).测试通过数据库连接池获取连接对象

public class TestDruid {
    @Test
    public void getDruidConn() throws Exception {
        Properties pros = new Properties();
        InputStream is = ClassLoader.getSystemClassLoader().getResourceAsStream("Druid.properties");
        pros.load(is);
        //所有的数据连接池要想被java所使用,都必须先实现sun公司提供的一个接口DateSource
        //获取数据库连接池对象
        DataSource source = DruidDataSourceFactory.createDataSource(pros);
        Connection conn = source.getConnection();
        System.out.println(conn);

    }
}

(四).测试结果(创建成功)

阿里巴巴主流数据库连接池Druid入门

五.Druid数据库连接池常见配置参数

阿里巴巴主流数据库连接池Druid入门

 阿里巴巴主流数据库连接池Druid入门

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163551.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • iptable 理解

    iptable 理解这个当初我理解不了,主要是没把netfilter理解清楚。Netfilter是集成在内核中的,用来定义存储各种规则的。Iptalbe是修改这些规则的工具,修改后存在netfilter里面。数据包进入LINUX服务器时,先进入服务器的netfilter模块中进行判断处理。 Netfilter包含有三种表,三种表下共包含有五种链,链下面包含各种规则。即表包含若干链,链包含若干规则。 …

    2022年5月28日
    97
  • 圆柱体积怎么算立方公式_圆柱体积计算公式 怎么计算

    圆柱体积怎么算立方公式_圆柱体积计算公式 怎么计算各位家长好,我是家长无忧(jiazhang51.cn)专栏作者,七玥老师全文共计767字,建议阅读2分钟圆柱体是由2个底边和一个侧边构成的。在同一个平面图内有一条定平行线和一条功能分区,当这一平面图绕着这条定平行线转动一周时,这条功能分区所成的面称为转动面,这条定平行线称为转动面的轴,这条功能分区称为转动面的母线槽。圆柱体的界定1、旋转定义法:一个长方形以一边为轴顺时针方向或反方向转动一周,所历经…

    2022年9月20日
    2
  • pycharmPyCharm 2021.8.3安装激活码【永久激活】

    (pycharmPyCharm 2021.8.3安装激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~KU…

    2022年3月22日
    63
  • mysql日期格式转换_MySQL日期格式转换

    mysql日期格式转换_MySQL日期格式转换DATE_FORMAT(date,format):根据参数对date进行格式化。1234SELECTDATE_FORMAT(‘2016-01-1622:23:00′,’%W%M%Y’)SELECTDATE_FORMAT(‘2016-01-1622:23:00′,’%D%y%a%d%m%b%j’)SELECTDATE_FORMAT(‘2016-01-1622:23:00’…

    2022年6月15日
    25
  • 2020朝花夕拾-不务正业的大学生做了什么比赛?[通俗易懂]

    2020朝花夕拾-不务正业的大学生做了什么比赛?[通俗易懂]朝花夕拾,旧事重提之意。恰逢CSDN年终征文,所以写作本文为年终总结,实为大学四年的总结,和CSDN一起成长参与各类竞赛的回忆。四年里和小伙伴们一起辛苦奋斗做了那么多比赛,当比赛结束,那些作品便无人问津了,放在学校的犄角旮旯里随着时间风化,也许并没有那么完善,但是对于当时付出时间和精力的我们来说,尤为珍贵,因此今天将它们一一回顾,作为纪念。

    2022年6月3日
    40
  • JetBrains IntelliJ IDEA 优化教程[通俗易懂]

    IntelliJIDEA最佳配置IntelliJIDEA分为两个版本:旗舰版(Ultimate)和社区版(Community)。旗舰版收费(30天免费使用时间,功能齐全);社区版(永久免费,功能简陋)。1.安装目录结构解释[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QkuuRlpv-1599207123456)(IntelliJ%20IDEA%E6%9C%80%E4%BD%B3%E9%85%8D%E7%BD%AE.assets/image-20200904150

    2022年4月16日
    119

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号