`
ybyonline
  • 浏览: 41084 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

Proxool连接池

 
阅读更多

 

proxool

 

Proxool是一种Java数据库连接池技术。是sourceforge下的一个开源项目,这个项目提供一个健壮、易用的连接池,最为关键的是这个连接池提供监控的功能,方便易用,便于发现连接泄漏的情况。

  目前是和DBCP以及C3P0一起,最为常见的三种JDBC连接池技术。

  日前,Hibernate官方宣布由于Bug太多不再支持DBCP,而推荐使用 Proxool或C3P0。

  Proxool在Hibernate中的典型配置如下:

  配置步聚

  (1) 建立proxool.xml文件,路径为根目录src下即与hibernate.cfg.xml同目录,内容如下:

  <?xml version="1.0" encoding="UTF-8"?>

  <!--
  the proxool configuration can be embedded within your own application's.
  Anything outside the "proxool" tag is ignored.
  -->
  <something-else-entirely>
  <proxool>
  <alias>mssqlProxool</alias>
  <driver-url>jdbc:sqlserver://XXX.XXX.XXX.XX:1433;databaseName=XXX</driver-url>
  <driver-class>com.microsoft.sqlserver.jdbc.SQLServerDriver</driver-class>
  <driver-properties>
  <property name="user" value="sa" />
  <property name="password" value="XXX" />
  </driver-properties>
  <house-keeping-test-sql>select CURRENT_DATE</house-keeping-test-sql>
  <house-keeping-sleep-time>90000</house-keeping-sleep-time>
  <simultaneous-build-throttle>20</simultaneous-build-throttle>
  <maximum-connection-count>100</maximum-connection-count>
  <minimum-connection-count>10</minimum-connection-count>
  <maximum-connection-lifetime>3600000</maximum-connection-lifetime>
  </proxool>
  </something-else-entirely>
 

  属性列表说明:

  fatal-sql-exception: 它是一个逗号分割的信息片段.当一个SQL异常发生时,他的异常信息将与这个信息片段进行比较.如果在片段中存在,那么这个异常将被认为是个致命错误 (Fatal SQL Exception ).这种情况下,数据库连接将要被放弃.无论发生什么,这个异常将会被重掷以提供给消费者.用户最好自己配置一个不同的异常来抛出.

  fatal-sql-exception-wrapper-class:正如上面所说,你最好配置一个不同的异常来重掷.利用这个属性,用户可以包装

  SQLException,使他变成另外一个异常.这个异常或者继承SQLException或者继承字RuntimeException.proxool

  自带了2个实现:'org.logicalcobwebs.proxool.FatalSQLException' 和'org.logicalcobwebs.proxool.FatalRuntimeException'.后者更合适.

  house-keeping-sleep-time: house keeper 保留线程处于睡眠状态的最长时间,house keeper 的职责就是检查各个连接的状态,并判断是否需要销毁或者创建.

  house-keeping-test-sql: 如果发现了空闲的数据库连接.house keeper 将会用这个语句来测试.这个语句最好非常快的被执行.如果没有定义,测试过程将会被忽略。

  injectable-connection-interface: 允许proxool实现被代理的connection对象的方法.

  injectable-statement-interface: 允许proxool实现被代理的Statement 对象方法.

  injectable-prepared-statement-interface: 允许proxool实现被代理的PreparedStatement 对象方法.

  injectable-callable-statement-interface: 允许proxool实现被代理的CallableStatement 对象方法.

  jmx: 如果属性为true,就会注册一个消息Bean到jms服务,消息Bean对象名: "Proxool:type=Pool, name=<alias>". 默认值为false.

  jmx-agent-id: 一个逗号分隔的JMX代理列表(如使用MBeanServerFactory.findMBeanServer(String agentId)注册的连接池。)这个属性是仅当"jmx"属性设置为"true"才有效。所有注册jmx服务器使用这个属性是不确定的

  jndi-name: 数据源的名称

  maximum-active-time: 如果housekeeper 检测到某个线程的活动时间大于这个数值.它将会杀掉这个线程.

  所以确认一下你的服务器的带宽.然后定一个合适的值.默认是5分钟.

  maximum-connection-count: 最大的数据库连接数.

  maximum-connection-lifetime: 一个线程的最大寿命.

  minimum-connection-count: 最小的数据库连接数

  overload-without-refusal-lifetime: 这可以帮助我们确定连接池的状态。如果我们已经拒绝了一个连接在这个设定值(毫秒),然后被认为是超载。默认为60秒。

  prototype-count: 连接池中可用的连接数量.如果当前的连接池中的连接少于这个数值.新的连接将被建立

  (假设没有超过最大可用数).例如.我们有3个活动连接2个可用连接,而我们的prototype-count是4,那么数

  据库连接池将试图建立另外2个连接.这和 minimum-connection-count不同. minimum-connection-count

  把活动的连接也计算在内.prototype-count 是spare connections 的数量.

  recently-started-threshold: 这可以帮助我们确定连接池的状态,连接数少还是多或超载。只要至少有一个连接已开始在此值(毫秒)内,或者有一些多余的可用连接,那么我们假设连接池是开启的。默认为60秒

  simultaneous-build-throttle: 这是我们可一次建立的最大连接数。那就是新增的连接请求,但还没有可供使用的连接。由于连接可以使用多线程,在有限的时间之间建立联系从而带来可用连接,但是我们需要通过一些方式确认一些线程并不是立即响应连接请求的,默认是10。

  statistics: 连接池使用状况统计。参数“10s,1m,1d”

  statistics-log-level: 日志统计跟踪类型。参数“ERROR”或 “INFO”

  test-before-use: 如果为true,在每个连接被测试前都会服务这个连接,如果一个连接失败,那么将被丢弃,另一个连接将会被处理,如果所有连接都失败,一个新的连接将会被建立。否则将会抛出一个SQLException异常。

  test-after-use: 如果为true,在每个连接被测试后都会服务这个连接,使其回到连接池中,如果连接失败,那么将被废弃。

  trace: 如果为true,那么每个被执行的SQL语句将会在执行期被log记录(DEBUG LEVEL).你也可以注册一个ConnectionListener (参看ProxoolFacade)得到这些信息.

  (2)修改hibernate.cfg.xml文件,内容如下:

  <?xml version='1.0' encoding='UTF-8'?>

  <!DOCTYPE hibernate-configuration PUBLIC
  "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
  "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
  <!-- Generated by MyEclipse Hibernate Tools. -->
  <hibernate-configuration>
  <session-factory>
  <property name="hibernate.proxool.pool_alias">mssqlProxool</property>
  <property name="hibernate.proxool.xml">proxool.xml</property>
  <property name="hibernate.connection.provider_class">org.hibernate.connection.ProxoolConnectionProvider</property>
  <property name="hibernate.proxool.existing_pool">true</property>
  <property name="dialect">org.hibernate.dialect.SQLServerDialect</property>
  <property name="hibernate.cache.use_query_cache">true</property>
  </session-factory>
  </hibernate-configuration>
 

  这里需注意三点:

  1.别名与proxool中的别名保持一致.

  2.路径确保正确

  3一般网上只说明了以上两点,hibernate.proxool.existing_pool 这个参数很重要

  hibernate.proxool.existing_pool:此值设为 false,当 hibernate 开始被调用时,就会初始化 proxool,进行数据库连接等操作;

  (3)要让程序直接使用proxool连接池,可以在web.xml中配置初始化servlet,在web容器加载的时候自动加载配置文件

  <servlet>

  <servlet-name>ServletConfigurator </servlet-name>

  <servlet-class>org.logicalcobwebs.proxool.configuration.ServletConfigurator</servlet-class>

  <init-param>

  <param-name>xmlFile</param-name>

  <param-value>/WEB-INF/classes/proxool.xml</param-value>

  </init-param>

  <load-on-startup>1</load-on-startup>

  </servlet>

 

  注意:如果同时配置了web.xml和hibernate.cfg.xml会产生错误:

  org.logicalcobwebs.proxool.ProxoolException: Parsing failed.

  因为同名的proxool连接池已经启动,而hibernate开始运行时会自己启动关联的proxool连接池.

  所以此时应改变hibernate.cfg.xml配置为:

  <property name="hibernate.proxool.existing_pool">true</property>

  (4)这一步是可选的 在应用中实时监控连接池

  <servlet>

  <servlet-name>adminProxool</servlet-name>
  <servlet-class>org.logicalcobwebs.proxool.admin.servlet.AdminServlet</servlet-class>
  </servlet>
  <servlet-mapping>
  <servlet-name>adminProxool</servlet-name>
  <url-pattern>/admin/proxool</url-pattern>
  </servlet-mapping>
 

  访问http://localhost:8080/项目名称/admin/proxool即可看到页面

  4.错误解析:

  常遇到的问题是

  org.hibernate.HibernateException:Proxool Provider unable to load JAXP configurator file:proxool.xml

  这有可能是由于proxool包版本的问题,我先后试过proxool-0.9.0RC1 proxool-0.9.0RC2 proxool-0.9.0RC3

  proxool-0.9.0 proxool-0.9.1 结果是高版本的0.9.0和0.9.1都会有这个问题,使用RC1或者以下的版本则没有.

 

 

 

 

 

 spring中以dataSource方式使用proxool连接池

 

(by goodhumor)

 

方式一:

 在Spring的"applicationContext.xml"中的dataSource bean定义——

 

 

<bean id="dataSource"
    class="org.logicalcobwebs.proxool.ProxoolDataSource">
    <property name="driver">
        <value>com.mysql.jdbc.Driver</value>
    </property>
    <property name="driverUrl">
        <value>jdbc:mysql://localhost:3306/dbname?user=yourname&amp;password=yourpass</value>
    </property>
    <property name="user" value="yourname" />
    <property name="password" value="yourpass" />
    <property name="alias" value="Pool_dbname" />
    <property name="houseKeepingSleepTime" value="90000" />
    <property name="prototypeCount" value="0" />
    <property name="maximumConnectionCount" value="50" />
    <property name="minimumConnectionCount" value="2" />
    <property name="simultaneousBuildThrottle" value="50" />
    <property name="maximumConnectionLifetime" value="14400000" />
    <property name="houseKeepingTestSql" value="select CURRENT_DATE" />
</bean>
 

 

第一种方式需要把用户名和密码写在连接串里面,

ProxoolDataSource类提供的user,password属性似乎没有什么用。

无论提供什么,它都会以空用户名、密码去连接数据库。

这可能是Proxool RC0.93的一个bug。

不过配置中的user,password两个属性还必须设置,否则hibernate会报空指针错误。

 

方式二:

 在Spring的"applicationContext.xml"中的dataSource bean定义——

 

<bean id="dataSource"
    class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName">
        <value>org.logicalcobwebs.proxool.ProxoolDriver</value>
    </property>
    <property name="url">
        <value>proxool.Pool_dbname</value>
    </property>
</bean>
 

 

 

第二种方式需要预先在"web.xml"先配置好Proxool连接池,配置如下:

 

 

 

<servlet>
    <servlet-name>proxoolServletConfigurator</servlet-name>
    <servlet-class>
        org.logicalcobwebs.proxool.configuration.ServletConfigurator
    </servlet-class>
    <init-param>
        <param-name>xmlFile</param-name>
        <param-value>WEB-INF/proxool.xml</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
</servlet>

<servlet>
    <servlet-name>context</servlet-name>
    <servlet-class>
        org.springframework.web.context.ContextLoaderServlet
    </servlet-class>
    <load-on-startup>2</load-on-startup>
</servlet>
 

注意,第二种方式下Spring的上下文加载如果想使用listener方式(Struts2要求),

则与连接池有关的Bean全得延迟初始化。因为listener比servlet优先初始化,

如果相关Bean不是lazy-init的话,则启动服务器时会出现Bean找不到连接定义的异常。

 

 <listener>

  <listener-class>

      org.springframework.web.context.ContextLoaderListener

  </listener-class>

 </listener>

 

 

其中proxool的配置文件可以采用xmlFile"proxool.xml"或者propertyFile"proxool.properties"

 

"proxool.xml"格式如下:

 

<?xml version="1.0" encoding="UTF-8"?>
<proxool-config>
   <proxool>
      <alias>Pool_dbname</alias>
      <driver-url>jdbc:mysql://localhost:3306/dbname</driver-url>
      <driver-class>com.mysql.jdbc.Driver</driver-class>
      <driver-properties>
      <property name="user" value="yourname"/>
      <property name="password" value="yourpass"/>
      </driver-properties>
      <house-keeping-sleep-time>60000</house-keeping-sleep-time>
      <maximum-connection-count>20</maximum-connection-count> 
      <minimum-connection-count>2</minimum-connection-count>
      <prototype-count>0</prototype-count>
      <simultaneous-build-throttle>20</simultaneous-build-throttle>
      <house-keeping-test-sql>select CURRENT_DATE</house-keeping-test-sql>
      <statistics>15s,10m,1d</statistics>
      <statistics-log-level>INFO</statistics-log-level>
   </proxool>
   <proxool>
    <!--可以配置多个库-->
   </proxool>
</proxool-config>

"proxool.properties"格式如下:

jdbc-0.proxool.alias=Pool_dbname
jdbc-0.proxool.driver-url=jdbc:mysql://localhost:3306/dbname
jdbc-0.proxool.driver-class=com.mysql.jdbc.Driver
jdbc-0.user=yourname
jdbc-0.password=yourpass
jdbc-0.proxool.house-keeping-sleep-time=60000
jdbc-0.proxool.house-keeping-test-sql=select CURRENT_DATE
jdbc-0.proxool.maximum-connection-count=10
jdbc-0.proxool.minimum-connection-count=3
jdbc-0.proxool.maximum-connection-lifetime=18000000
jdbc-0.proxool.prototype-count=3
jdbc-0.proxool.simultaneous-build-throttle=10
jdbc-0.proxool.recently-started-threshold=60000
jdbc-0.proxool.overload-without-refusal-lifetime=50000
jdbc-0.proxool.maximum-active-time=60000
jdbc-0.proxool.verbose=true
jdbc-0.proxool.trace=true
jdbc-0.proxool.fatal-sql-exception=Fatal error

jdbc-2.proxool.alias=Pool_dbname2
……
<!--可以配置多个库-->
 

 

-----------------------------------------------------------

 

个人比较倾向于第二种配置方式,

一来可以避免在Spring的"applicationContext.xml"中写一大堆参数,

尤其是避免了driverUrl中带用户名密码(这会显示在proxool包中带的

org.logicalcobwebs.proxool.admin.servlet.AdminServlet输出的页面中)

 

二来proxool连接池可以在tomcat启动时就初始化好,可以提高第一次访问web时的连接速度。

 

 

如果直接引用链接池,实例如下:

 

public class ConnectionPool {

        private static ConnectionPool pool;

        private ConnectionPool() {
                try {
                        JAXPConfigurator.configure("proxool.xml", false);
                } catch (ProxoolException e) {
                        e.printStackTrace();
                }
        }

        public static ConnectionPool getInstance() {
                synchronized (ConnectionPool.class) {
                        if (pool == null) {
                                pool = new ConnectionPool();
                        }
                }
                return pool;
        }

        public Connection getConnection() throws SQLException {
                return DriverManager.getConnection("proxool.data_center");
        }
}
 

 

分享到:
评论

相关推荐

    proxool连接池用户名密码加密

    总之,"proxool连接池用户名密码加密"是一个重要的安全实践,通过加密数据库连接的凭证,我们可以提高系统的安全性,保护数据免受未经授权的访问。正确地配置和使用这个功能,可以确保在享受数据库连接池带来的性能...

    proxool连接池使用详细说明

    Proxool连接池是数据库连接管理的一种解决方案,它允许应用程序高效地管理和复用数据库连接,以提高系统的性能和响应速度。下面将详细讲解Proxool连接池的使用方法及其核心概念。 1. **Proxool简介** Proxool是...

    proxool连接池配置文件

    项目实用的proxool连接池配置文件,每个标签都有注释,可以直接拿来使用

    在Hibernate中配置Proxool连接池

    本篇将详细介绍如何在Hibernate中配置Proxool连接池。 首先,我们需要在Spring的配置文件`applicationContext.xml`中设置SessionFactory Bean。SessionFactory是Hibernate的核心组件,它负责创建Session对象,而...

    proxool连接池配置详解

    ### Proxool连接池配置详解 #### 一、概述 Proxool是一个开源的轻量级Java数据库连接池实现,其主要目标是替代常见的数据库连接池解决方案,如C3P0或DBCP,并且提供了更加灵活和易于配置的特性。在实际应用中,...

    ssh2简单案例,注解+proxool连接池+sf4j记录日志

    在这个"ssh2简单案例"中,我们将探讨如何结合注解、Proxool连接池和SF4J日志记录来构建一个SSH2注册登录系统。 首先,SSH2在Java中的实现通常通过JSch库来完成。JSch允许开发者在Java程序中执行命令、传输文件以及...

    proxool连接池所涉及的jar包文件

    在本压缩包中,包含的是与Proxool连接池相关的MySQL驱动jar包,这将有助于在Java应用程序中建立与MySQL数据库的连接。 首先,我们来深入理解一下Proxool连接池。Proxool的核心功能是创建一个池化的数据库连接集合,...

    Spring+Hibernate+Proxool连接池

    标题 "Spring+Hibernate+Proxool连接池" 涉及到的是在Java Web开发中,如何使用Spring框架集成Hibernate ORM框架,并结合Proxool作为数据库连接池的技术实践。这通常是为了提高应用性能,有效管理和复用数据库连接,...

    Proxool连接池使用方法

    Proxool连接池使用方法 首先, 你要把下载 proxool 的 lib 下面所有的 jar 文件, 放到 WEB-INF/lib 下面, 另外, 把你的 jdbc driver 也放到相同的 lib,

    proxool连接池

    **Proxool 连接池详解** Proxool 是一个高效、易用的数据库连接池,它通过提供中间代理层管理数据库连接,从而实现数据库连接的复用,提高应用程序的性能和效率。Proxool 的设计目标是为 Java 应用程序提供简单、...

    proxool连接池配置

    -- 连接池的别名 --&gt; &lt;alias&gt;DBPool&lt;/alias&gt; - &lt;!-- proxool只能管理由自己产生的连接 --&gt; &lt;driver-url&gt;jdbc:sqlserver://localhost:1433;dataBaseName=books&lt;/driver-url&gt; - &lt;!-- JDBC驱动程序 --&gt; ...

    Proxool连接池jar包

    Proxool连接池是数据库连接管理的一个开源工具,它提供了一种高效且灵活的方式来管理和复用数据库连接,以提升应用程序的性能和响应速度。在Java应用程序中,尤其是在高并发环境下,数据库连接池扮演着至关重要的...

    proxool连接池jar包

    `proxool连接池jar包`是一个包含Proxool数据库连接池技术的软件包。Proxool作为源码开放的项目,源自著名的开源平台SourceForge,它为Java开发者提供了一个高效且易于管理的数据库连接池解决方案。数据库连接池在多...

    Hibernate Proxool连接池配置总结及常遇问题

    **Hibernate Proxool连接池配置详解** 在Java应用程序中,数据库连接池是管理数据库连接的一种高效方式,它可以显著提升系统性能,减少数据库资源的浪费。本文将深入探讨Hibernate与Proxool连接池的配置,以及在...

    基于ssh的proxool连接池配置

    下面我们将深入探讨基于SSH的Proxool连接池配置。 首先,配置环境:MyEclipse5.5,Windows 2003操作系统,Oracle和MySQL数据库。在这样的环境中,Proxool连接池可以帮助我们更高效地管理数据库连接,提高应用程序的...

    Proxool连接池实例.zip

    在这个"Proxool连接池实例.zip"压缩包中,我们可以推测包含了一些关于如何在C#环境下集成和使用Proxool连接池的示例代码和相关资源。 首先,让我们深入理解一下Proxool连接池的工作原理。Proxool维护了一个数据库...

    Proxool连接池配置

    标题与描述均聚焦于“Proxool连接池配置”,这一主题是Java开发中数据库连接管理的重要环节。Proxool作为一款轻量级的开源数据库连接池实现,它提供了高效的数据库连接管理和复用机制,旨在减少应用程序创建和销毁...

    ssh小框架(proxool连接池)

    **Proxool连接池**:Proxool是数据库连接池的一种实现,它的主要作用是管理数据库连接,减少创建和销毁连接的开销。当多个用户请求数据库连接时,Proxool会复用已存在的连接,而不是每次请求都新建一个。这大大提高...

    proxool连接池.txt

    ### Proxool连接池知识点详解 #### 一、Proxool连接池简介 Proxool是Logical Cobwebs公司开发的一款轻量级的JDBC连接池组件。它通过提供高效的数据库连接管理和复用机制来提高应用程序的性能。Proxool不仅支持多种...

Global site tag (gtag.js) - Google Analytics