您的位置:首页 > 数据库

JDBC数据库连接池c3po配置

2014-03-05 15:49 295 查看
使用前需要先导入c3po开源jar包,

import java.sql.Connection;

import java.sql.SQLException;

import com.mchange.v2.c3p0.ComboPooledDataSource;

import com.mchange.v2.c3p0.DataSources;

public class ConnectionManager {

        private static ConnectionManager instance;

        private ComboPooledDataSource ds;

        private ConnectionManager() throws Exception {

            

            ds = new ComboPooledDataSource();

            ds.setDriverClass("oracle.jdbc.driver.OracleDriver");

            ds.setJdbcUrl("jdbc:oracle:thin:@192.168.1.210:1521:orcl2");

            ds.setUser("abc");

            ds.setPassword("123456");

            ds.setInitialPoolSize(3);//初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 initialPoolSize

            ds.setMaxPoolSize(10);//连接池中保留的最大连接数。Default: 15 maxPoolSize

            ds.setMinPoolSize(1);// 连接池中保留的最小连接数。

            ds.setAcquireIncrement(1);//当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 acquireIncrement

            ds.setIdleConnectionTestPeriod(60);//每60秒检查所有连接池中的空闲连接。Default: 0  idleConnectionTestPeriod

            ds.setMaxIdleTime(25000);  //最大空闲时间,25000秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0  maxIdleTime

            ds.setAutoCommitOnClose(true); //连接关闭时默认将所有未提交的操作回滚。Default: false autoCommitOnClose

            

            /**

             * 注释------------------------------------------------------------------------

             */

            //定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。注意:

            //测试的表必须在初始数据源的时候就存在。Default: null  preferredTestQuery

            //ds.setPreferredTestQuery("select sysdate from dual");

            // 因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的

            // 时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable

            // 等方法来提升连接测试的性能。Default: false testConnectionOnCheckout

            /**

             * 注释------------------------------------------------------------------------

             */

            

            ds.setTestConnectionOnCheckout(true);

            //如果设为true那么在取得连接的同时将校验连接的有效性。Default: false  testConnectionOnCheckin

            ds.setTestConnectionOnCheckin(true);

            

            ds.setAcquireRetryAttempts(10);//定义在从数据库获取新连接失败后重复尝试的次数。Default: 30  acquireRetryAttempts

            

            ds.setAcquireRetryDelay(1000);//两次连接中间隔时间,单位毫秒。Default: 1000 acquireRetryDelay

            //获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效

            //保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试

            //获取连接失败后该数据源将申明已断开并永久关闭。Default: false  breakAfterAcquireFailure

            ds.setBreakAfterAcquireFailure(true);

           

        }

        public static final ConnectionManager getInstance() {

            if (instance == null) {

                try {

                    instance = new ConnectionManager();

                } catch (Exception e) {

                    e.printStackTrace();

                }

            }

            return instance;

        }

        public synchronized final Connection getConnection() {

            try {

                return ds.getConnection();

            } catch (SQLException e) {

                e.printStackTrace();

            }

            return null;

        }

        protected void finalize() throws Throwable {

            DataSources.destroy(ds); //关闭datasource

            super.finalize();

        }

    

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息