Java Web中使用数据库连接池proxool配置详解

使用proxool数据库连接池步骤:

  1. 在WEB-INF的lib中导入proxool-0.9.0RC3.jar
  2. 在WEB-INF中新建一个XML文件,取名为proxool.xml
  3. 在proxool.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>smms</alias> <!--数据源的别名-->
                    <driver-url>jdbc:mysql://127.0.0.1:3306/smms</driver-url><!--url连接串-->
                    <driver-class>com.mysql.jdbc.Driver</driver-class><!--驱动类-->
                    <driver-properties>
                            <property name="user" value="root" /><!--用户名-->
                            <property name="password" value="root" /><!--密码-->
                    </driver-properties>         
                    <!--最大连接数(默认 5个),超过了这个连接数,再有请求时,就排在队列中等候,最大的等待请求数由
    
    maximum-new-connections决定-->
                    <maximum-connection-count>100</maximum-connection-count>
                    <!--最小连接数(默认2个)-->
                    <minimum-connection-count>10</minimum-connection-count>
                    <!--proxool自动侦察各个连接状态的时间间隔(毫秒),侦察到空闲的连接就马上回收,超时的销毁  默
    
    认30秒-->
                    <house-keeping-sleep-time>90000</house-keeping-sleep-time>
                    <!--没有空闲连接可以分配而在队列中等候的最大请求数,超过这个请求数的用户连接就不会被接受-
    
    ->
                    <maximum-new-connections>10</maximum-new-connections>
                    <!--最少保持的空闲连接数(默认2个)-->
                    <prototype-count>5</prototype-count>
                    <!--在使用之前测试-->
                    <test-before-use>true</test-before-use>
                    <!--用于保持连接的测试语句  -->
                    <house-keeping-test-sql>select id from t_sysadmin</house-keeping-test-sql>
         </proxool>
    </something-else-entirely>

  4. 在web.xml中添加以下节点:
      <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/proxool.xml</param-value>     
       </init-param>     
       <load-on-startup>1</load-on-startup>     
    </servlet>


  5. 数据库操作类如下:
    package cn.edu.hbcit.smms.dao.databasedao;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    
    import org.apache.log4j.Logger;
    
    import org.logicalcobwebs.proxool.ProxoolException;       
    import org.logicalcobwebs.proxool.ProxoolFacade;       
    import org.logicalcobwebs.proxool.admin.SnapshotIF;
    /**
     * 数据库操作类
     * @author lw
     *
     */
    public class DBConn {
    	private static Connection conn;
    	private static ResultSet rs;
    	private static PreparedStatement ps;
    	private static String driverClass = "org.logicalcobwebs.proxool.ProxoolDriver";//proxool驱动类
    	//private static String url = "jdbc:mysql://localhost:3306/bbs?user=root&password=123";
    	private static int activeCount = 0; //活动连接数
    	protected final Logger log = Logger.getLogger(DBConn.class.getName());
    	
        /**
         * 获取数据库连接
         * @return Connection
         */
    	public Connection getConn() {
    		try {
    			Class.forName(driverClass); 
    			conn = DriverManager.getConnection("proxool.smms"); //此处的smms是在proxool.xml中配置的连接池别名
    			this.showSnapshotInfo(); //查看连接池信息
    		} catch (Exception e) {
    			log.error(e.getMessage());
    			log.debug("数据库连接错误!");
    			//System.out.println(e.getMessage());
    			//System.out.println("数据库连接错误!");
    		}
    		return conn;
    	}
    	
    	/**     
         * 释放连接     
         * freeConnection     
         * @param conn     
         */
    	public void freeConnection(Connection conn){
            if(conn!=null){
                try {
                    conn.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    	
    
    	/**
    	 * 获取连接池中的连接信息
    	 */
    	private void showSnapshotInfo(){
            try{       
                SnapshotIF snapshot = ProxoolFacade.getSnapshot("smms", true);       
                int curActiveCount=snapshot.getActiveConnectionCount();//获得活动连接数       
                int availableCount=snapshot.getAvailableConnectionCount();//获得可得到的连接数       
                int maxCount=snapshot.getMaximumConnectionCount() ;//获得总连接数       
                if(curActiveCount!=activeCount)//当活动连接数变化时输出的信息       
                {
                	log.debug("活动连接数:"+curActiveCount+"(active);可得到的连接数:"+availableCount+"(available);总连接数:"+maxCount+"(max)");
                 //System.out.println("活动连接数:"+curActiveCount+"(active);可得到的连接数:"+availableCount+"(available);总连接数:"+maxCount+"(max)");                    
                 activeCount=curActiveCount;       
                }
            }catch(ProxoolException e){       
                e.printStackTrace();       
            }       
        }  
    
    }
    



你可能感兴趣的:(Java Web)