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();
}
}
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();
}
}
相关文章推荐
- jdbc环境配置以及进行简单的增 删 改
- SSM中jdbc.properties的配置
- 配置JDBC报, java.sql.SQLException: Access denied for user 'root'@'localhost' (using password: YES)错误原因
- maven 项目 spring mvc + jdbc 配置文件
- 通过配置文件实现通用的jdbc链接
- spring(数据库)jdbc配置、spring与jdbc编程的结合和jdbc模板方式的使用
- javaweb_day7(JDBC)的配置信息提取到配置文件
- spring的xml配置文件中获取jdbc.properties乱码导致连接数据库失败
- 从零开始学JDBC--1.9 代码抽取--使用Properties读取配置文件
- spring mvc +spring jdbc配置
- JDBC | 从配置文件中读取驱动
- 在spring中使用JDBC事务配置
- c3p0、dbcp、tomcat jdbc pool 连接池配置简介及常用数据库的driverClass和驱动包
- spring配置ibatis的jdbc方式和proxool连接池方式
- Sharding-JDBC 源码分析 —— SQL 路由(一)之分库分表配置
- 【Spring】spring-mvc hibernate druid jdbc等数据源事务配置详解(解决注解事务不生效问题)
- URL错误导致WebLogic配置JDBC时找不到合适的驱动。
- JAVA通过JDBC连接MSSQL的配置方法
- Tomcat7 新的数据库连接池Tomcat jdbc pool介绍和配置
- jdbc工具类通过配置文件连接数据库学习理解