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

本文介绍了数据库连接池的必要性,详细阐述了其工作原理、优点,并对比了多种开源数据库连接池。重点讲解了Druid连接池的配置与使用,包括创建properties文件、创建连接池、获取连接对象的步骤,并展示了成功创建的测试结果。最后列举了Druid的常见配置参数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

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

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

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

二.数据库连接池技术

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

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

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

(四).工作原理:

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

1.资源重用:

2.更快的反应速度:

3.数据库共享机制

4.避免内存泄漏:

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

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

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

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

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

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

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


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

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

        1.在主程序中创建连接

        2.进行sql操作

        3.关闭数据库连接

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

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

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

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

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

二.数据库连接池技术

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

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

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

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

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

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

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

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

(四).工作原理:

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

1.资源重用:

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

2.更快的反应速度:

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

3.数据库共享机制

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

4.避免内存泄漏:

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

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

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

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

DBCP:速度比C3P0快但有bug

c3p0:速度慢,但相对稳定

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

BoneCP:速度快,开源

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

四.学习最主流的数据库连接池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数据库连接池常见配置参数

 

### 解决数据库连接池溢出超时问题 #### 设置合理的最大连接数 为了防止过多的数据库连接请求超出连接池能够处理的能力,应合理设置最大连接数。当应用程序对数据库连接的需求波动较大时,过高的最大连接数可能会导致资源耗尽;而过低则可能使部分请求进入等待队列,从而影响响应速度和用户体验[^2]。 ```java // 配置数据源属性 DataSource dataSource = new DataSource(); dataSource.setMaxActive(10); // 设定最大活跃连接数目为10 ``` #### 实现任务排队机制并优化并发控制 对于高并发场景下的大量瞬时访问,可以通过实现任务排队机制来缓解压力。通过限制同时执行的任务数量,并让多余的请求暂时挂起直到有可用资源为止,这样既能保证系统的稳定运行又能提高整体效率[^3]。 ```python from concurrent.futures import ThreadPoolExecutor, as_completed def process_db_request(request): # 处理单个数据库请求逻辑 pass executor = ThreadPoolExecutor(max_workers=5) future_to_req = {executor.submit(process_db_request, req): req for req in db_requests} for future in as_completed(future_to_req): try: result = future.result() print('Request processed:', result) except Exception as exc: print('Request generated an exception:', exc) ``` #### 定期监控与动态调整策略 定期检查当前使用的连接情况有助于及时发现潜在的风险点。利用内置函数获取有关连接池大小、已借出/归还的数量等信息可以帮助管理员了解实时状况,并据此做出相应决策,比如增加或减少允许的最大活动连接数以适应负载变化。 ```python import time while True: status = monitor_pool_status() # 获取连接池状态 if status['overflow'] > 0 or (status['checkedout']/status['pool_size']) >= 0.8: adjust_max_connections(status) # 动态调整最大连接数 time.sleep(60) # 每隔一分钟监测一次 ```
评论 68
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值