Не удалось проверить режим автоматической фиксации JDBC, соединение уже закрыто ОШИБКА

#java #hibernate #tomcat #sybase #connection-pooling

#java #спящий режим #tomcat #sybase #объединение в пул соединений

Вопрос:

При попытке подключиться к внешней Sybase базе данных я получаю приведенный ниже stacktrace. Однако, когда я перезапускаю процесс подключения к базе данных, после этого все работает отлично.

Я использую приведенные ниже конфигурации. Похоже, что соединение внезапно закрывается, и как только я перезапускаю процесс, он снова создает новое соединение. Должен ли я настроить что-либо parameter в DataSource или connection pool , чтобы сохранить connection открытым и не закрывать его резко?

Источник данных

 <bean id="dataSource" class="org.apache.tomcat.jdbc.pool.DataSource"
        destroy-method="close">
        <property name="driverClassName" value="com.sybase.jdbc4.jdbc.SybDriver" />
        <property name="url" value="******"/>
        <property name="username" value="*******"/>
        <property name="password" value="*******" />
        <property name="connectionProperties" value="ENCRYPT_PASSWORD=true;JCE_PROVIDER_CLASS=org.bouncycastle.jce.provider.BouncyCastleProvider" />             
        
    </bean>
  

SessionFactory

 <bean id="hibernateTemplate"
    class="org.springframework.orm.hibernate3.HibernateTemplate"
    scope="prototype">
    <property name="sessionFactory" ref="sessionFactory"></property>
</bean>

<bean id="sessionFactory"
    class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
    <property name="dataSource">
        <ref local="dataSource" />
    </property>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.SybaseDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop>
            <prop key="hibernate.cache.use_second_level_cache">false</prop>
        </props>
    </property>
    <property name="mappingResources">
        <list>
            <value>************</value> 
        </list>
    </property>
</bean>
  

ТРАССИРОВКА СТЕКА

 org.springframework.dao.TransientDataAccessResourceException: Hibernate operation: could not inspect JDBC autocommit mode; SQL [???]; JZ0C0: Connection is already closed.; nested exception is java.sql.SQLException: JZ0C0: Connection is already closed.
    at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:106)
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:72)
    at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)
    at org.springframework.orm.hibernate3.HibernateAccessor.convertJdbcAccessException(HibernateAccessor.java:424)
    at org.springframework.orm.hibernate3.HibernateAccessor.convertHibernateAccessException(HibernateAccessor.java:410)
    at org.springframework.orm.hibernate3.HibernateTemplate.doExecute(HibernateTemplate.java:424)
    at org.springframework.orm.hibernate3.HibernateTemplate.execute(HibernateTemplate.java:339)
Caused by: java.sql.SQLException: JZ0C0: Connection is already closed.
    at com.sybase.jdbc4.jdbc.ErrorMessage.raiseError(Unknown Source)
    at com.sybase.jdbc4.jdbc.SybConnection.checkConnection(Unknown Source)
    at com.sybase.jdbc4.jdbc.SybConnection.getAutoCommit(Unknown Source)
    at sun.reflect.GeneratedMethodAccessor2.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.apache.tomcat.jdbc.pool.ProxyConnection.invoke(ProxyConnection.java:126)
    at org.apache.tomcat.jdbc.pool.JdbcInterceptor.invoke(JdbcInterceptor.java:99)
    at org.apache.tomcat.jdbc.pool.DisposableConnectionFacade.invoke(DisposableConnectionFacade.java:63)
    at com.sun.proxy.$Proxy0.getAutoCommit(Unknown Source)
    at org.hibernate.jdbc.ConnectionManager.isAutoCommit(ConnectionManager.java:189)
    at org.hibernate.jdbc.JDBCContext.afterNontransactionalQuery(JDBCContext.java:243)
    at org.hibernate.impl.SessionImpl.afterOperation(SessionImpl.java:417)
    at org.hibernate.impl.SessionImpl.listCustomQuery(SessionImpl.java:1701)
    at org.hibernate.impl.AbstractSessionImpl.list(AbstractSessionImpl.java:142)
    at org.hibernate.impl.SQLQueryImpl.list(SQLQueryImpl.java:152)
    at com.b2conshore.testing.B2COnshoreSybaseTesting$1.doInHibernate(B2COnshoreSybaseTesting.java:39)
    at com.b2conshore.testing.B2COnshoreSybaseTesting$1.doInHibernate(B2COnshoreSybaseTesting.java:1)
    at org.springframework.orm.hibernate3.HibernateTemplate.doExecute(HibernateTemplate.java:419)
    ... 2 more
  

Комментарии:

1. Есть ли брандмауэр между приложением и базой данных. Если да, то это может быть вероятной причиной прерывания соединения. Попробуйте установить эти свойства пула, которые будут проверять незанятое соединение и проверять соединение перед передачей приложению testOnBorrow= true,testWhileIdle=true вместе с набором свойств validationQuery. Включите эти свойства в компонент DataSource

2. Вы можете найти больше об этих свойствах здесь tomcat.apache.org/tomcat-8.5-doc/jdbc-pool.html