org.deegree.commons.jdbc.ConnectionPool.java Source code

Java tutorial

Introduction

Here is the source code for org.deegree.commons.jdbc.ConnectionPool.java

Source

//$HeadURL: svn+ssh://mschneider@svn.wald.intevation.org/deegree/base/trunk/resources/eclipse/files_template.xml $
/*----------------------------------------------------------------------------
 This file is part of deegree, http://deegree.org/
 Copyright (C) 2001-2009 by:
 Department of Geography, University of Bonn
 and
 lat/lon GmbH
    
 This library is free software; you can redistribute it and/or modify it under
 the terms of the GNU Lesser General Public License as published by the Free
 Software Foundation; either version 2.1 of the License, or (at your option)
 any later version.
 This library is distributed in the hope that it will be useful, but WITHOUT
 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
 details.
 You should have received a copy of the GNU Lesser General Public License
 along with this library; if not, write to the Free Software Foundation, Inc.,
 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
    
 Contact information:
    
 lat/lon GmbH
 Aennchenstr. 19, 53177 Bonn
 Germany
 http://lat-lon.de/
    
 Department of Geography, University of Bonn
 Prof. Dr. Klaus Greve
 Postfach 1147, 53001 Bonn
 Germany
 http://www.geographie.uni-bonn.de/deegree/
    
 e-mail: info@deegree.org
 ----------------------------------------------------------------------------*/

package org.deegree.commons.jdbc;

import static org.slf4j.LoggerFactory.getLogger;

import java.sql.Connection;
import java.sql.SQLException;

import org.apache.commons.dbcp.ConnectionFactory;
import org.apache.commons.dbcp.DelegatingConnection;
import org.apache.commons.dbcp.DriverManagerConnectionFactory;
import org.apache.commons.dbcp.PoolableConnectionFactory;
import org.apache.commons.dbcp.PoolingDataSource;
import org.apache.commons.pool.impl.GenericObjectPool;
import org.deegree.commons.annotations.LoggingNotes;
import org.slf4j.Logger;

/**
 * Simple implementation of a JDBC connection pool based on the Apache Commons Pool and DBCP projects.
 * 
 * @author <a href="mailto:schneider@lat-lon.de">Markus Schneider</a>
 * @author last edited by: $Author: schneider $
 * 
 * @version $Revision: $, $Date: $
 */
@LoggingNotes(debug = "logs information about pool usage")
public class ConnectionPool {

    private static final Logger LOG = getLogger(ConnectionPool.class);

    private final String id;

    private final PoolingDataSource ds;

    private final GenericObjectPool<Connection> pool;

    /**
     * Creates a new {@link ConnectionPool} instance.
     * 
     * @param id
     * @param connectURI
     * @param user
     * @param password
     * @param readOnly
     * @param minIdle
     * @param maxActive
     */
    public ConnectionPool(String id, String connectURI, String user, String password, boolean readOnly, int minIdle,
            int maxActive) {

        this.id = id;
        pool = new GenericObjectPool<Connection>(null);
        pool.setMinIdle(minIdle);
        pool.setMaxActive(maxActive);

        ConnectionFactory connectionFactory = new DriverManagerConnectionFactory(connectURI, user, password);
        // TODO make this configurable
        new PoolableConnectionFactory(connectionFactory, pool, null, null, readOnly, true);
        ds = new PoolingDataSource(pool);
        // needed, so users can retrieve the underlying connection from pooled
        // connections, e.g. to access the
        // LargeObjectManager from a PGConnection
        ds.setAccessToUnderlyingConnectionAllowed(true);
    }

    /**
     * Returns a {@link Connection} from the pool.
     * 
     * @return a connection from the pool
     * @throws SQLException
     */
    public Connection getConnection() throws SQLException {
        LOG.debug("For connection id '{}': active connections: {}, idle connections: {}",
                new Object[] { id, pool.getNumActive(), pool.getNumIdle() });
        return ds.getConnection();
    }

    /**
     * @throws Exception
     */
    public void destroy() throws Exception {
        pool.close();
    }

    public void invalidate(DelegatingConnection conn) throws Exception {
        conn.getDelegate().close();
        pool.invalidateObject(conn);
    }
}