Postgresql + Hibernate3 + C3p0 = не закрывать соединения - PullRequest
0 голосов
/ 10 августа 2011

Это происходит только до пиковой нагрузки системы.

Исключение гибернации:

org.hibernate.exception.JDBCConnectionException: could not execute query

org.postgresql.util.PSQLException: произошла ошибка ввода-вывода при отправке на серверную часть. java.io.IOException: поток закрыт

postgresql log entry: 2011-08-10 05:27:35 UTC LOG:  unexpected EOF on clien

т соединение

Вот мой спящий XML-файл

<!-- Database connection settings -->
    <property name="connection.driver_class">org.postgresql.Driver</property>
    <property name="connection.url">jdbc:postgresql://[url]/sa_server</property>
    <property name="connection.username">[user]</property>
    <property name="connection.password">[pw]</property>
    <property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
    <property name="hibernate.c3p0.min_size">3</property>
    <property name="hibernate.c3p0.max_size">5</property>
    <property name="hibernate.c3p0.timeout">1800</property>
    <property name="hibernate.c3p0.idle_test_period">100</property>

    <!-- SQL dialect -->
    <property name="hibernate.dialect">org.hibernatespatial.postgis.PostgisDialect</property>

    <property name="current_session_context_class">thread</property>

    <!-- Disable the second-level cache  -->
    <property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>

    <!-- Echo all executed SQL to stdout -->
    <property name="show_sql">false</property>    

EDIT ----

Вот код, который я звоню, чтобы получить и закрыть сеанс.

// perform the operation itself
    try {
        session = AppSessionFactory.openSession();
        session.beginTransaction();
        session.setFlushMode( FlushMode.COMMIT );
        if ( pre() ) {
            if ( doWork() ) {
                if ( post() ) {
                    session.getTransaction().commit();
                }
            }
        }
        if ( !response.success ) {
            session.getTransaction().rollback();
        }
    } catch ( Exception e ) {

        if ( session != null ) {
            try { session.getTransaction().rollback(); } catch ( Exception e2 ) {}
        }

        // attempt to retrieve a useful error for the invoker
        outerException = e;
        Throwable cause = outerException.getCause();
        if ( cause != null && cause instanceof SQLException ) {
            Exception rootCause = ((SQLException)cause).getNextException();
            if ( rootCause != null ) {
                innerException = rootCause;
            }
        }
    } finally {
        if ( session != null ) { session.close(); }
    }

EDIT -

public class AppSessionFactory {

private static AppSessionFactory instance = null;
private final SessionFactory sessionFactory = 
    new Configuration()
        .configure() // configures settings from hibernate.cfg.xml
        .buildSessionFactory();

private AppSessionFactory() {}

@Override
protected void finalize() {
    if ( sessionFactory != null ) {
        sessionFactory.close();
    }
}

private static AppSessionFactory instance() {
    if ( instance == null ) {
        instance = new AppSessionFactory();
    }
    return instance;
}

public static Session openSession() {
    return instance().sessionFactory.openSession();
}
* *} Тысяча двадцать-один

Ответы [ 2 ]

1 голос
/ 02 апреля 2012

У нас была такая же проблема, и мы перешли на BoneCP. Теперь все работает нормально. У нас есть сайт с высокой нагрузкой и пиками 3000 просмотров в секунду. Решение от kgibbon пыталось, но у нас не получилось.

0 голосов
/ 11 августа 2011

решение: добавлено testConnectionOnCheckout = true и testConnectionOnCheckin = true в конфигурацию c3p0.

...