分类: Oracle
2009-10-28 18:02:45
作为开源的连接池Proxool有以下优点
透明性 可以明的添加接连池而不影响你原来的项目的JDBC代码;
开放性 你可以方便的与其它的开源产品进行整合。如hibernate 中自带的这个Proxool
标准性 它是在J2SE下开出来的。你可以放心的开发
易用性 非常容易 的进行配置。
proxool是一个非常强大的连接池工具包,我觉得相比dbcp、c3p0这两个连接池包都要好用,我用loadrunner测试过,这三个连接池的从性能上排名如下:proxool>c3p0>dbcp,特别是dbcp在大并发的情况下总是出现各种异常。
下面是实现proxool的几种方式:
JDBC连接方法:
首先建一个proxool的配置文件proxool.xml
proxool.xml 代码
xml version="1.0" encoding="UTF-8"?><proxool> DBPool jdbc:oracle:thin:@192.168.0.40:1521:drcom oracle.jdbc.driver.OracleDriver 90000 150 3 100 3 proxool>
再在web.xml中进行配置,其中的ServletConfigurator是装载WEB-INF目录下的proxool.xml,并设置为Tomcat启动时就加载。Admin这个Servlet是proxool提供的察看连接池的信息的工具,
web.xml 代码
xml version="1.0" encoding="UTF-8"?>ServletConfigurator org.logicalcobwebs.proxool.configuration.ServletConfigurator xml WEB-INF/proxool.xml 1 Admin org.logicalcobwebs.proxool.admin.servlet.AdminServlet Adminservlet-name> /adminurl-pattern> TestServlet selfservice.TestServlet TestServlet /TestServlet
以上配置完成后,第三步就可以创建一个连接池的类了
package selfservice; import java.sql.Connection; imp ort java.sql.DriverManager; imp ort java.sql.ResultSet; imp ort java.sql.SQLException; imp ort java.sql.Statement; imp ort org.logicalcobwebs.proxool.ProxoolException; imp ort org.logicalcobwebs.proxool.ProxoolFacade; imp ort org.logicalcobwebs.proxool.admin.SnapshotIF; public class PoolManager { private static int activeCount = 0; public PoolManager(){ } /** * 获取连接 * getConnection * @param name * @return */ public Connection getConnection() { try{ Class.forName("org.logicalcobwebs.proxool.ProxoolDriver");//proxool驱动类 Connection conn = DriverManager.getConnection("proxool.DBPool"); //此处的DBPool是在proxool.xml中配置的连接池别名 showSnapshotInfo(); return conn; }catch(Exception ex){ ex.printStackTrace(); } return null; } /** * 此方法可以得到连接池的信息 * showSnapshotInfo */ private void showSnapshotInfo(){ try{ SnapshotIF snapshot = ProxoolFacade.getSnapshot("DBPool", true); int curActiveCount=snapshot.getActiveConnectionCount();//获得活动连接数 int availableCount=snapshot.getAvailableConnectionCount();//获得可得到的连接数 int maxCount=snapshot.getMaximumConnectionCount() ;//获得总连接数 if(curActiveCount!=activeCount)//当活动连接数变化时输出的信息 { System.out.println("活动连接数:"+curActiveCount+"(active) 可得到的连接数:"+availableCount+"(available) 总连接数:"+maxCount+"(max)"); activeCount=curActiveCount; } }catch(ProxoolException e){ e.printStackTrace(); } } /** * 获取连接 * getConnection * @param name * @return */ public Connection getConnection(String name){ return getConnection(); } /** * 释放连接 * freeConnection * @param conn */ public void freeConnection(Connection conn){ if(conn!=null){ try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } /** * 释放连接 * freeConnection * @param name * @param con */ public void freeConnection (String name,Connection con){ freeConnection(con); } public void getQuery() { try { Connection conn = getConnection(); if(conn != null){ Statement statement = conn.createStatement(); ResultSet rs = statement.executeQuery("select * from tblgxinterface"); int c = rs.getMetaData().getColumnCount(); while(rs.next()){ System.out.println(); for(int i=1;i<=c;i++){ System.out.print(rs.getObject(i)); } } rs.close(); } freeConnection(conn); } catch (SQLException e) { e.printStackTrace(); } } }
就这样我们完成了一个连接池的功能。proxool的连接池我用loadrunner进行大并发的测试,性能还是很好的。
Hibernate中proxool连接池的方式:
首先步骤跟JDBC的连接池一样,也是新建一个proxool.xml配置文件,再在web.xml中配置,具体参考上面。
第二步在hibernate的配置文件hibernate.cfg.xml中配置proxool连接设置:
hibernate.cfg.xml代码
org.hibernate.connection.ProxoolConnectionProvider DBPool proxoolconf.xml
Spring中proxool连接池的方式
首先布骤与JDBC的连接池一样,先建一个proxool.xml配置文件,再在web.xml中配置,具体参考上面的。
第二步在spring配置文件applicationContext.xml中配置proxool连接设置
applicationContext.xml代码