1. package com.c3p0.datapools;

  2. //数据库连接池  单例模式

  3. import java.sql.Connection;

  4. import java.sql.SQLException;

  5. import com.mchange.v2.c3p0.ComboPooledDataSource;

  6. import com.mchange.v2.c3p0.DataSources;

  7. public final class ConnectionManager {

  8. private static ConnectionManager instance;

  9. private ComboPooledDataSource ds;

  10. private ConnectionManager() throws Exception {

  11. ds = new ComboPooledDataSource();

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

  13. ds.setJdbcUrl("jdbc:oracle:thin:@127.0.0.1:1521:orcl");

  14. ds.setUser("scott");

  15. ds.setPassword("tiger");

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

  17. ds.setInitialPoolSize(3);

  18. //连接池中保留的最大连接数。Default:  15 maxPoolSize

  19. ds.setMaxPoolSize(100);

  20. //// 连接池中保留的最小连接数。

  21. //ds.setMinPoolSize(1);

  22. //当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 acquireIncrement

  23. ds.setAcquireIncrement(10);

  24. //每60秒检查所有连接池中的空闲连接。Default: 0  idleConnectionTestPeriod

  25. ds.setIdleConnectionTestPeriod(60);

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

  27. ds.setMaxIdleTime(25000);

  28. //连接关闭时默认将所有未提交的操作回滚。Default: false autoCommitOnClose

  29. ds.setAutoCommitOnClose(true);

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

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

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

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

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

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

  36. ds.setTestConnectionOnCheckout(true);

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

  38. ds.setTestConnectionOnCheckin(true);

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

  40. ds.setAcquireRetryAttempts(30);

  41. //两次连接中间隔时间,单位毫秒。Default: 1000 acquireRetryDelay

  42. ds.setAcquireRetryDelay(1000);

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

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

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

  46. ds.setBreakAfterAcquireFailure(true);

  47. //        <!--当连接池用完时客户端调用getConnection()后等待获取新连接的时间,超时后将抛出

  48. //        SQLException,如设为0则无限期等待。单位毫秒。Default: 0 -->

  49. //        <property name="checkoutTimeout">100</property>

  50. //        <!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么

  51. //        属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试

  52. //        使用。Default: null-->

  53. //        <property name="automaticTestTable">Test</property>

  54. //        <!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements

  55. //        属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。

  56. //        如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default: 0-->

  57. //        <property name="maxStatements">100</property>

  58. //        <!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default: 0 -->

  59. //        <property name="maxStatementsPerConnection"></property>

  60. //        <!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能

  61. //        通过多线程实现多个操作同时被执行。Default: 3-->

  62. //        <property name="numHelperThreads">3</property>

  63. //        <!--用户修改系统配置参数执行前最多等待300秒。Default: 300 -->

  64. //        <property name="propertyCycle">300</property>

  65. }

  66. public  static  final ConnectionManager getInstance() {

  67. if (instance == null) {

  68. try {

  69. instance = new ConnectionManager();

  70. } catch (Exception e) {

  71. e.printStackTrace();

  72. }

  73. }

  74. return instance;

  75. }

  76. public synchronized   final Connection getConnection() {

  77. try {

  78. return ds.getConnection();

  79. } catch (SQLException e) {

  80. e.printStackTrace();

  81. }

  82. return null;

  83. }

  84. protected void finalize() throws Throwable {

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

  86. super.finalize();

  87. }

  88. }

经典的单例模式c3p0来控制数据库连接池的更多相关文章

  1. 数据库复用代码【c3p0配置文件、数据库连接池】

    前言 为了复用,记载一些以前写过的工具类.方法 c3p0配置文件[c3p0-config.xml] <?xml version="1.0" encoding="UT ...

  2. C3P0和Druid数据库连接池

    目录 C3P0连接池 步骤: C3P0初始化: 创建C3P0工具类: 创建C3P0测试类: Druid连接池(由阿里巴巴提供的数据库连接池实现技术) 步骤: Druid初始化: 创建Druid工具类: ...

  3. 资源池模式和单例模式实现的自定义数据库连接池java实现版

    在企业级开发中,我们往往不会直接使用原生的JDBC操作来实现与数据库得连接.因为数据库的连接是一个很宝贵的资源且耗时,我们往往会在内存中引入一个资源池来统一管理数据库的连接.这个模式也被总结为一种设计 ...

  4. 开源数据库连接池之C3P0

    本篇介绍几种开源数据库连接池,同时重点讲述如何使用C3P0数据库连接池. 之前的博客已经重点讲述了使用数据库连接池的好处,即是将多次创建连接转变为一次创建而使用长连接模式.这样能减少数据库创建连接的消 ...

  5. [原创]java WEB学习笔记80:Hibernate学习之路--- hibernate配置文件:JDBC 连接属性,C3P0 数据库连接池属性等

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  6. c3p0数据库连接池管理

    之前已经讲过dbcp可以用于数据库连接池进行管理.另一种技术c3p0也可以用于数据库连接池管理,其中Spring等框架都是基于c3p0技术进行数据库连接池管理的. 使用之前需要引入 c3p0-0.9. ...

  7. 通过实现ServletContextListener接口创建数据库连接池(C3P0方式)

    使用Listener步骤 1. 定义Listener实现类 2. 在web.xml中配置(或使用Annotation) 使用C3P0方式创建数据库连接池需要添加的jar包 1.c3p0-0.9.5.j ...

  8. 数据库连接池——C3P0&Druid(快速入门)

    数据库连接池--C3P0&Druid (一) 数据库连接池 每一个事物都有其存在的意义,在初学jdbc的时候,我们建立数据库连接对象后,会对其进行释放,但是数据库连接的建立和关闭是非常消耗资源 ...

  9. Druid数据库连接池就这么简单

    前言 本章节主要讲解Druid数据库连接池,为什么要学Druid数据库连接池呢?? 我的知识储备数据库连接池有两种->C3P0,DBCP,可是现在看起来并不够用阿~当时学习C3P0的时候,觉得这 ...

随机推荐

  1. kvm安装及配置

     yum install kvm libvirt python-virtinst qemu-kvm virt-viewer bridge-utils virt-install 修改网卡信息 /etc/ ...

  2. RHEL7虚拟机中不重启的情况下加新硬盘及扩展根分区容量

    在VMware中添加一块新的5G硬盘 显示当前分区 # fdisk -l 通常在你在虚拟机中添加一块新硬盘时,你可能会看到新硬盘没有自动加载.这是因为连接到硬盘的SCSI总线需要重新扫描来使得新硬盘可 ...

  3. js - 多个函数动态加载

    //动态添加物流锁的IEMI列表. function createLi() { var r = '<s:property value="#session.locks"/> ...

  4. OC - 18.监听iPhone的网络状态

    使用系统的方法来监听网络状态 系统的方法是通过通知机制来实现网络状态的监听 实现网络状态监听的步骤 定义Reachability类型的成员变量来保存网络的状态 @property (nonatomic ...

  5. 【html】【0】开始的序言

    人生总得做点什么才显得有意义,在牛逼的梦想也抵挡不住你傻逼似的坚持! 1>本系列适用于没有任何计算机语言基础的小白入门级教程 2>为了我喜欢的一个女生小娜娜 3>为自己系统的学习ht ...

  6. ie6常见的兼容性

    1.IE6怪异解析之padding与border算入宽高 原因:未加文档声明造成非盒模型解析 解决方法:加入文档声明<!doctype html> 2.IE6在块元素.左右浮动.设定mar ...

  7. angularjs应用骨架(2)

    时隔一个星期,接着上一篇的angularjs应用骨架继续聊聊angularjs其他的其他的内容. 区分UI和控制器的职责 在应用控制器中有三种职责: 1.为应用中模型设置初始状态 2.通过$scope ...

  8. LINUX 添加定时任务

    LINUX 添加定时任务 crontab - l按 i:x 先按 esc然后 敲入 命令 :x*/5 3 * * 0 /root/ v.sh ..重启服务 service crond restart

  9. Activity启动模式图文详解

    转载自:http://jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0520/2897.html  英文原文:Understand Android A ...

  10. 帝国cms7.0修改默认搜索模版中的分页[!--show.page--]

    修改默认搜索模版的分页是在e/class/connect.php下 搜索下function page1就是我们要修改的分页了 下面贴上我修改后的分页 //前台分页 function page1($nu ...