经典的单例模式c3p0来控制数据库连接池
- package com.c3p0.datapools; 
- //数据库连接池 单例模式 
- import java.sql.Connection; 
- import java.sql.SQLException; 
- import com.mchange.v2.c3p0.ComboPooledDataSource; 
- import com.mchange.v2.c3p0.DataSources; 
- public final 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:@127.0.0.1:1521:orcl"); 
- ds.setUser("scott"); 
- ds.setPassword("tiger"); 
- //初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 initialPoolSize 
- ds.setInitialPoolSize(3); 
- //连接池中保留的最大连接数。Default: 15 maxPoolSize 
- ds.setMaxPoolSize(100); 
- //// 连接池中保留的最小连接数。 
- //ds.setMinPoolSize(1); 
- //当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 acquireIncrement 
- ds.setAcquireIncrement(10); 
- //每60秒检查所有连接池中的空闲连接。Default: 0 idleConnectionTestPeriod 
- ds.setIdleConnectionTestPeriod(60); 
- //最大空闲时间,25000秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 maxIdleTime 
- ds.setMaxIdleTime(25000); 
- //连接关闭时默认将所有未提交的操作回滚。Default: false autoCommitOnClose 
- ds.setAutoCommitOnClose(true); 
- //定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。注意: 
- //测试的表必须在初始数据源的时候就存在。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); 
- //定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 acquireRetryAttempts 
- ds.setAcquireRetryAttempts(30); 
- //两次连接中间隔时间,单位毫秒。Default: 1000 acquireRetryDelay 
- ds.setAcquireRetryDelay(1000); 
- //获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效 
- //保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试 
- //获取连接失败后该数据源将申明已断开并永久关闭。Default: false breakAfterAcquireFailure 
- ds.setBreakAfterAcquireFailure(true); 
- // <!--当连接池用完时客户端调用getConnection()后等待获取新连接的时间,超时后将抛出 
- // SQLException,如设为0则无限期等待。单位毫秒。Default: 0 --> 
- // <property name="checkoutTimeout">100</property> 
- // <!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么 
- // 属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试 
- // 使用。Default: null--> 
- // <property name="automaticTestTable">Test</property> 
- // <!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements 
- // 属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。 
- // 如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 0--> 
- // <property name="maxStatements">100</property> 
- // <!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0 --> 
- // <property name="maxStatementsPerConnection"></property> 
- // <!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能 
- // 通过多线程实现多个操作同时被执行。Default: 3--> 
- // <property name="numHelperThreads">3</property> 
- // <!--用户修改系统配置参数执行前最多等待300秒。Default: 300 --> 
- // <property name="propertyCycle">300</property> 
- } 
- 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(); 
- } 
- } 
经典的单例模式c3p0来控制数据库连接池的更多相关文章
- 数据库复用代码【c3p0配置文件、数据库连接池】
		前言 为了复用,记载一些以前写过的工具类.方法 c3p0配置文件[c3p0-config.xml] <?xml version="1.0" encoding="UT ... 
- C3P0和Druid数据库连接池
		目录 C3P0连接池 步骤: C3P0初始化: 创建C3P0工具类: 创建C3P0测试类: Druid连接池(由阿里巴巴提供的数据库连接池实现技术) 步骤: Druid初始化: 创建Druid工具类: ... 
- 资源池模式和单例模式实现的自定义数据库连接池java实现版
		在企业级开发中,我们往往不会直接使用原生的JDBC操作来实现与数据库得连接.因为数据库的连接是一个很宝贵的资源且耗时,我们往往会在内存中引入一个资源池来统一管理数据库的连接.这个模式也被总结为一种设计 ... 
- 开源数据库连接池之C3P0
		本篇介绍几种开源数据库连接池,同时重点讲述如何使用C3P0数据库连接池. 之前的博客已经重点讲述了使用数据库连接池的好处,即是将多次创建连接转变为一次创建而使用长连接模式.这样能减少数据库创建连接的消 ... 
- [原创]java WEB学习笔记80:Hibernate学习之路--- hibernate配置文件:JDBC 连接属性,C3P0 数据库连接池属性等
		本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ... 
- c3p0数据库连接池管理
		之前已经讲过dbcp可以用于数据库连接池进行管理.另一种技术c3p0也可以用于数据库连接池管理,其中Spring等框架都是基于c3p0技术进行数据库连接池管理的. 使用之前需要引入 c3p0-0.9. ... 
- 通过实现ServletContextListener接口创建数据库连接池(C3P0方式)
		使用Listener步骤 1. 定义Listener实现类 2. 在web.xml中配置(或使用Annotation) 使用C3P0方式创建数据库连接池需要添加的jar包 1.c3p0-0.9.5.j ... 
- 数据库连接池——C3P0&Druid(快速入门)
		数据库连接池--C3P0&Druid (一) 数据库连接池 每一个事物都有其存在的意义,在初学jdbc的时候,我们建立数据库连接对象后,会对其进行释放,但是数据库连接的建立和关闭是非常消耗资源 ... 
- Druid数据库连接池就这么简单
		前言 本章节主要讲解Druid数据库连接池,为什么要学Druid数据库连接池呢?? 我的知识储备数据库连接池有两种->C3P0,DBCP,可是现在看起来并不够用阿~当时学习C3P0的时候,觉得这 ... 
随机推荐
- CSS hack常用方案(摘选)
			邮箱因为默认了line-height?:170%,导致采用table元素时继承问题,可以采用line-height:50% 很好解决. 常 在使用float时,后面的显示不正常,因为继承了float了 ... 
- IT技能栈
			C++.JAVA.Objective-C 基本数据类型,集合类如字符串数组字典,自定义数据对象 内存布局,编译运行期的变化 语言特性 输入输出流,文件流,序列化 多线程,并发控制,线程池,锁 网络编程 ... 
- CentOS 6.7 配置nginx支持SSL/https访问
			一.安装必要的包 yum install openssl openssl-devel 二.配置编译参数,增加对SSL的支持 ./configure –with-http_ssl_module 三.修改 ... 
- fsdfasfsa
			http://www.cnblogs.com/daniel206/archive/2008/01/16/1041729.html using System.IO;using System.Net;us ... 
- HTML+CSS基础学习笔记(8)
			一.水平居中设置--行内元素 如果设置元素为文本.图片等行内元素时,水平居中是通过给父元素设置text-align:center来实现的 二.水平居中设置 --定宽块状元素 #当被设置元素为块状元素时 ... 
- (转)PHP中文处理 中文字符串截取(mb_substr)和获取中文字符串字数
			一.中文截取:mb_substr() mb_substr( $str, $start, $length, $encoding ) $str,需要截断的字符串 $start,截断开始处,起始处为0 $l ... 
- [Excel] C#GridViewExport帮助类,美化导出 (转载)
			主要功能如下1.将整GridView的数据导出到Excel中关增加一个效果线做美化最新的GridViewExport操作类看下面代码吧 /// <summary> /// 类说明:Grid ... 
- 使用methodSignatureForSelector与forwardInvocation实现消息转发 (转)
			转自:http://blog.sina.com.cn/s/blog_8c87ba3b0102v006.html 在给程序添加消息转发功能以前,必须覆盖两个方法,即methodSignatureForS ... 
- C#中检查网络是否连通的二种方法
			using System; 2 using System.Collections.Generic; 3 using System.Text; 4 //方法一 5 using System.Ru ... 
- XhProf安装教程–详细教程
			wget去这里找最新的包下载,我现在最新的是xhprof-0.9.4.tgz cd /tmp mkdir xhprof && cd xhprof wget http://pecl.ph ... 
