1. package com.sinoglobal.db;
  2. import java.sql.Connection;
  3. import java.sql.DriverManager;
  4. import java.sql.ResultSet;
  5. import java.sql.SQLException;
  6. import java.sql.Statement;
  7. import java.util.Locale;
  8. import java.util.ResourceBundle;
  9. import org.apache.commons.dbcp.ConnectionFactory;
  10. import org.apache.commons.dbcp.DriverManagerConnectionFactory;
  11. import org.apache.commons.dbcp.PoolableConnectionFactory;
  12. import org.apache.commons.dbcp.PoolingDriver;
  13. import org.apache.commons.pool.ObjectPool;
  14. import org.apache.commons.pool.impl.GenericObjectPool;
  15. @SuppressWarnings("unchecked")
  16. public class PoolManager {
  17. private static String driver = "net.sourceforge.jtds.jdbc.Driver"; // 驱动
  18. private static String url = ""; // URL
  19. private static String name = "sa"; // 用户名
  20. private static String password = ""; // 密码
  21. private static Class driverClass = null;
  22. private static ObjectPool connectionPool = null;
  23. private static String poolname = "";
  24. private static ResourceBundle rb;
  25. /**
  26. * 初始化数据源
  27. */
  28. private static synchronized void initDataSource() {
  29. if (driverClass == null) {
  30. try {
  31. driverClass = Class.forName(driver);
  32. } catch (ClassNotFoundException e) {
  33. e.printStackTrace();
  34. }
  35. }
  36. }
  37. /**
  38. * 装配配置文件 initProperties
  39. */
  40. private static void loadProperties() {
  41. rb = ResourceBundle.getBundle("config", Locale.getDefault());
  42. driver = rb.getString("jdbc.sql.driverClassName");
  43. url = rb.getString("jdbc.sql.url");
  44. name = rb.getString("jdbc.sql.username");
  45. password = rb.getString("jdbc.sql.password");
  46. poolname = rb.getString("jdbc.sql.poolname");
  47. }
  48. /**
  49. * 连接池启动
  50. *
  51. * @throws Exception
  52. */
  53. public static void StartPool() {
  54. loadProperties();
  55. initDataSource();
  56. if (connectionPool != null) {
  57. ShutdownPool();
  58. }
  59. try {
  60. connectionPool = new GenericObjectPool(null);
  61. ConnectionFactory connectionFactory = new DriverManagerConnectionFactory(
  62. url, name, password);
  63. new PoolableConnectionFactory(connectionFactory, connectionPool,
  64. null, null, false, true);
  65. Class.forName("org.apache.commons.dbcp.PoolingDriver");
  66. PoolingDriver driver = (PoolingDriver) DriverManager
  67. .getDriver("jdbc:apache:commons:dbcp:");
  68. driver.registerPool(poolname, connectionPool);
  69. } catch (Exception e) {
  70. e.printStackTrace();
  71. }
  72. }
  73. /**
  74. * 释放连接池
  75. */
  76. public static void ShutdownPool() {
  77. try {
  78. PoolingDriver driver = (PoolingDriver) DriverManager
  79. .getDriver("jdbc:apache:commons:dbcp:");
  80. driver.closePool(poolname);
  81. } catch (SQLException e) {
  82. e.printStackTrace();
  83. }
  84. }
  85. /**
  86. * 取得连接池中的连接
  87. *
  88. * @return
  89. */
  90. public static Connection getConnection() {
  91. Connection conn = null;
  92. if (connectionPool == null)
  93. StartPool();
  94. try {
  95. conn = DriverManager.getConnection("jdbc:apache:commons:dbcp:"
  96. + poolname);
  97. } catch (SQLException e) {
  98. e.printStackTrace();
  99. }
  100. return conn;
  101. }
  102. /**
  103. * 获取连接 getConnection
  104. *
  105. * @param name
  106. * @return
  107. */
  108. public static Connection getConnection(String name) {
  109. return getConnection();
  110. }
  111. /**
  112. * 释放连接 freeConnection
  113. *
  114. * @param conn
  115. */
  116. public static void freeConnection(Connection conn) {
  117. if (conn != null) {
  118. try {
  119. conn.close();
  120. } catch (SQLException e) {
  121. e.printStackTrace();
  122. }
  123. }
  124. }
  125. /**
  126. * 释放连接 freeConnection
  127. *
  128. * @param name
  129. * @param con
  130. */
  131. public static void freeConnection(String name, Connection con) {
  132. freeConnection(con);
  133. }
  134. /**
  135. * 例子 main
  136. *
  137. * @param args
  138. */
  139. public static void main(String[] args) {
  140. try {
  141. Connection conn = PoolManager.getConnection();
  142. System.out.println(conn.isClosed());
  143. if (conn != null) {
  144. Statement statement = conn.createStatement();
  145. ResultSet rs = statement
  146. .executeQuery("select * from test2..log");
  147. int c = rs.getMetaData().getColumnCount();
  148. while (rs.next()) {
  149. System.out.println();
  150. for (int i = 1; i <= c; i++) {
  151. System.out.print(rs.getObject(i));
  152. }
  153. }
  154. rs.close();
  155. }
  156. PoolManager.freeConnection(conn);
  157. } catch (SQLException e) {
  158. e.printStackTrace();
  159. }
  160. }
  161. }

DBCP JAVA 连接池的更多相关文章

  1. DBCP数据源连接池实现原理分析

    前些天在调试公司系统的时候发现这样的一个问题:mysql数据库服务停止一段时间后再次重启后吗,tomcat服务无法请求数据库服务,调试了半天对这个问题进行定位解决,期间也搞了很多有关mysql数据库的 ...

  2. 几个主流java连接池

    池(Pool)技术在一定程度上可以明显优化服务器应用程序的性能,提高程序执行效率和降低系统资源开销.这里所说的池是一种广义上的池,比如数据库连接池.线程池.内存池.对象池等.其中,对象池可以看成保存对 ...

  3. 转载: 几个主流的Java连接池整理

    https://www.cnblogs.com/linjian/p/4831088.html 池(Pool)技术在一定程度上可以明显优化服务器应用程序的性能,提高程序执行效率和降低系统资源开销.这里所 ...

  4. 几个主流的Java连接池整理

    池(Pool)技术在一定程度上可以明显优化服务器应用程序的性能,提高程序执行效率和降低系统资源开销.这里所说的池是一种广义上的池,比如数据库连接池.线程池.内存池.对象池等.其中,对象池可以看成保存对 ...

  5. Java 连接池的工作原理(转)

    原文:Java 连接池的工作原理 什么是连接? 连接,是我们的编程语言与数据库交互的一种方式.我们经常会听到这么一句话“数据库连接很昂贵“. 有人接受这种说法,却不知道它的真正含义.因此,下面我将解释 ...

  6. [JavaEE] 了解Java连接池

    转载自51CTO http://developer.51cto.com/art/201006/207768.htm 51CTO曾经为我们简单的介绍过Java连接池.要了解Java连接池我们先要了解数据 ...

  7. Redis Java连接池调研

    Redis Java连接池调研 线上服务,由于压力大报错RedisTimeOut,但是需要定位到底问题出现在哪里? 查看Redis慢日志,slowlog get 发现耗时最大的也是11000us也就是 ...

  8. dbcp数据源连接池

    一.数据源连接池 我们之前利用jdbc连接数据库,每次都要创建连接对象,销毁连接对象,如果并发访问量比较大,这样肯定比较辣 浪费数据库的效率,我们可以像之前mybatis中缓存查询到的数据一样,可以把 ...

  9. Java 使用 DBCP mysql 连接池 做数据库操作

    需要的jar包有 commons-dbutils , commons-dbcp , commons-pool , mysql-connector-java 本地database.propertties ...

随机推荐

  1. 快速搭建Redis缓存数据库

    之前一篇随笔——Redis安装及主从配置已经详细的介绍过Redis的安装于配置.本文要讲的是如何在已经安装过Redis的机器上快速的创建出一个新的Redis缓存数据库. 一.环境介绍 1) Linux ...

  2. PHP String 函数

    [http://www.w3school.com.cn/php/php_ref_string.asp ] PHP String 简介 String 字符串函数允许您对字符串进行操作. 安装 Strin ...

  3. [thml]HTML select标签 获取选中的option的value及Text内容

    很简单的select标签: <select id="hello" onchange="getContent(this.value,this.options[this ...

  4. word中设置前几页为罗马数字,后几页设置为阿拉伯数字

    假如第1-5页摘要部分页脚要是罗马数字,第6页开始是正文部分是阿拉伯数字,起始页为1. WORD2003 1.将光标定位在第5页末尾处,在菜单栏中依次点击“插入——分隔符——(分节符类型)下一页”.按 ...

  5. Channel Allocation

    Channel Allocation Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 13231 Accepted: 6774 D ...

  6. Curling 2.0 分类: 搜索 2015-08-09 11:14 3人阅读 评论(0) 收藏

    Curling 2.0 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14289 Accepted: 5962 Descript ...

  7. Animator角色重复受击播放问题

    需要指定开始时间参数,否则Animator会默认当前已经在播放这个动画而忽略掉 CrossFade一样 gif: public class AnimatorDebug : MonoBehaviour ...

  8. php基础复习(3)文件上传于下载

    一. 客户端配置: 表单页面 表单的发送方式是post 添加enctype = “multipart/form-data”   <form action="doaction.php&q ...

  9. 解决json_encode中文UNICODE转码问题

    用PHP的json_encode来处理中文的时候, 中文都会被编码, 变成不可读的, 类似”\u***”的格式,如果想汉字不进行转码,这里提供三种方法 .升级PHP,在PHP5., 这个问题终于得以解 ...

  10. fffffffffff

    create proc partPage114 @n int,--每页数量 @page int, --页码从0开始 @Mainkey int as declare @sql nvarchar(1000 ...