利用Apache的CommonPool2编写连接池

本文介绍如何使用Maven配置依赖项,并通过Apache Commons Pool2实现了一个简单的JDBC连接池。该连接池支持从配置中设置最大连接数、空闲连接数等参数。

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

Maven配置

<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-pool2 -->
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-pool2</artifactId>
    <version>2.4.2</version>
</dependency>

废话少说,上代码

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import org.apache.commons.pool2.BasePooledObjectFactory;
import org.apache.commons.pool2.PooledObject;
import org.apache.commons.pool2.impl.DefaultPooledObject;
import org.apache.commons.pool2.impl.GenericObjectPool;
import org.apache.commons.pool2.impl.GenericObjectPoolConfig;

public class JDBCPool {

    // TODO
    private final static String URL = "jdbc:mysql://localhost:3306/activiti";
    private final static String USERNAME = "root";
    private final static String PASSWD = "root";
    private final static String DRIVER = "com.mysql.jdbc.Driver";

    private volatile static JDBCPool pool;

    public static JDBCPool getInstance() {
        if (pool == null) {
            synchronized (JDBCPool.class) {
                if (pool == null) {
                    pool = new JDBCPool();
                }
            }
        }
        return pool;
    }

    private static GenericObjectPool<Connection> connPool;

    private JDBCPool() {
        connPool = new GenericObjectPool<Connection>(new JDBCPooledFactory(),
                getDefaultConfig());
    }

    private GenericObjectPoolConfig getDefaultConfig() {
        GenericObjectPoolConfig conf = new GenericObjectPoolConfig();
        // TODO -- 默认8,8,0
        conf.setMaxTotal(50);
        conf.setMaxIdle(50);
        conf.setMinIdle(0);
        conf.setMaxWaitMillis(60000);
        return conf;
    }

    public JDBCPool(GenericObjectPoolConfig config) {
        if (config == null)
            config = getDefaultConfig();
        connPool = new GenericObjectPool<Connection>(new JDBCPooledFactory(),
                config);
    }

    public GenericObjectPool<Connection> getConnectionPool() {
        return connPool;
    }

    public Connection getConnection() throws Exception {
        return getConnectionPool().borrowObject();
    }

    public static void closePsAndRs(PreparedStatement ps, ResultSet rs) {
        if (rs != null) {
            try {
                rs.close();
            } catch (SQLException e) {
                rs = null;
            }
        }
        if (ps != null) {
            try {
                ps.close();
            } catch (SQLException e) {
                ps = null;
            }
        }
    }

    public static void returnConnection(Connection conn) {
        connPool.returnObject(conn);
    }

    public static void returnConnectionAndClose(Connection conn,
            PreparedStatement ps, ResultSet rs) {
        closePsAndRs(ps, rs);
        returnConnection(conn);
    }

    static class JDBCPooledFactory extends BasePooledObjectFactory<Connection> {
        static {
            try {
                Class.forName(DRIVER);
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            }
        }

        @Override
        public Connection create() throws Exception {
            return DriverManager.getConnection(URL, USERNAME, PASSWD);
        }

        @Override
        public PooledObject<Connection> wrap(Connection arg0) {
            return new DefaultPooledObject<Connection>(arg0);
        }
    }

    public static void main(String[] args) {
        try {
            for (int i = 0; i < 200; i++) {
//               // 1 单线程不归还连接
//               Connection conn = JDBCPool.getInstance().getConnection();
//               System.out.println(conn.hashCode());
//               // 2 单线程归还连接
//               JDBCPool.returnConnection(conn);
                // 3 多线程不归还
                new Thread(new PoolTestThread()).start();
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    private static class PoolTestThread implements Runnable {

        @Override
        public void run() {
            try {
                Connection conn = JDBCPool.getInstance().getConnection();
                System.out.println(Thread.currentThread().getName() + " : "
                        + conn.hashCode());
                // 4 多线程归还连接
                Thread.sleep(1000);
                JDBCPool.returnConnection(conn);
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }

    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值