首先從 http://
proxool.sourceforge.net/ 下載
proxool-0.9.0RC2.zip
解壓后,把proxool-0.9.0RC2.jar放到工程的lib文件夾里面。
proxool是一個非常強大的連接池工具包,我覺得相比dbcp、c3p0這兩個連接池包都要好用,我用loadrunner測試過,這三個連接池的從性能上排名如下:proxool>c3p0>dbcp,特別是dbcp在大并發(fā)的情況下總是出現(xiàn)各種異常。詳細關于dbcp的介紹請參考dbcp用戶指南,dbcp實現(xiàn)參考tvjody.javaeye.com/admin/show/117225。
下面是實現(xiàn)proxool的幾種方式:
JDBC連接方法:
首先建一個proxool的配置文件proxool.xml
proxool.xml 代碼
xml 代碼
- xml version="1.0" encoding="UTF-8"?>
-
-
-
- <something-else-entirely>
- <proxool>
-
- <alias>DBPoolalias>
-
- <driver-url>jdbc:oracle:thin:@192.168.0.40:1521:drcomdriver-url>
-
- <driver-class>oracle.jdbc.driver.OracleDriverdriver-class>
- <driver-properties>
- <property name="user" value="drcom"/>
- <property name="password" value="drcom"/>
- driver-properties>
-
- <house-keeping-sleep-time>90000house-keeping-sleep-time>
-
- <maximum-new-connections>150maximum-new-connections>
-
- <prototype-count>3prototype-count>
-
- <maximum-connection-count>100maximum-connection-count>
-
- <minimum-connection-count>3minimum-connection-count>
- proxool>
- something-else-entirely>
再在web.xml中進行配置,其中的ServletConfigurator是裝載WEB-INF目錄下的proxool.xml,并設置為Tomcat啟動時就加載。Admin這個Servlet是proxool提供的察看連接池的信息的工具,
web.xml 代碼
xml 代碼
- xml version="1.0" encoding="UTF-8"?>
- <web-app version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
- http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
- <servlet>
- <servlet-name>ServletConfiguratorservlet-name>
- <servlet-class>
- org.logicalcobwebs.proxool.configuration.ServletConfigurator
- servlet-class>
- <init-param>
- <param-name>xmlFileparam-name>
- <param-value>WEB-INF/proxool.xmlparam-value>
- init-param>
- <load-on-startup>1load-on-startup>
- servlet>
- <servlet>
- <servlet-name>Adminservlet-name>
- <servlet-class>
- org.logicalcobwebs.proxool.admin.servlet.AdminServlet
- servlet-class>
- servlet>
- <servlet-mapping>
- <servlet-name>Adminservlet-name>
- <url-pattern>/adminurl-pattern>
- servlet-mapping>
- <servlet>
- <servlet-name>TestServletservlet-name>
- <servlet-class>
- selfservice.TestServlet
- servlet-class>
- servlet>
- <servlet-mapping>
- <servlet-name>TestServletservlet-name>
- <url-pattern>/TestServleturl-pattern>
- servlet-mapping>
- web-app>
以上配置完成后,第三步就可以創(chuàng)建一個連接池的類了
java 代碼
就這樣我們完成了一個連接池的功能。proxool的連接池我用loadrunner進行大并發(fā)的測試,性能還是很好的。
Hibernate中proxool連接池的方式:
首先步驟跟JDBC的連接池一樣,也是新建一個proxool.xml配置文件,再在web.xml中配置,具體參考上面。
第二步在hibernate的配置文件hibernate.cfg.xml中配置proxool連接設置:
hibernate.cfg.xml代碼
xml 代碼
- <property name="hibernate.connection.provider_class">org.hibernate.connection.ProxoolConnectionProviderproperty>
- <property name="hibernate.proxool.pool_alias">DBPoolproperty>
- <property name="hibernate.proxool.xml">proxoolconf.xmlproperty>
Spring中proxool連接池的方式:
首先布驟與JDBC的連接池一樣,先建一個proxool.xml配置文件,再在web.xml中配置,具體參考上面的。
第二步在spring配置文件applicationContext.xml中配置proxool連接設置
applicationContext.xml代碼
xml 代碼
- <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" singleton="true">
- <property name="driverClassName" value="org.logicalcobwebs.proxool.ProxoolDriver"/>
- <property name="url" value="proxool.StatDBPool"/>
- bean>
- <bean id="transactionManager"
- class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource">
- <ref local="dataSource" />
- property>
- bean>
這樣spring就能得到一個dataSource的數(shù)據(jù)源。
proxool還有很多功能,我這只是簡單的應用。具體請察看proxool用戶指南。