如何处理:SQL错误:0,SQLState:08006和08003?

问题描述 投票:0回答:1

我在带有PostgreSQL数据库的heroku上有应用程序。解析器运行在我的PC上,每隔10分钟就会保存并从heroku的db中读取数据,并使用休眠模式进行交互。这是配置:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <property name="hibernate.connection.driver_class">org.postgresql.Driver</property>
        <property name="hibernate.connection.url">jdbc:postgresql:url</property>
        <property name="hibernate.connection.username">user</property>
        <property name="hibernate.connection.password">pass</property>
        <property name="hibernate.dialect">org.hibernate.dialect.PostgreSQL94Dialect</property>
        <property name="show_sql">true</property>

        <property name="hibernate.c3p0.idle_test_period">14400</property><property name="hibernate.c3p0.timeout">25200</property>
        <property name="hibernate.c3p0.max_size">15</property>
        <property name="hibernate.c3p0.min_size">3</property>
        <property name="hibernate.c3p0.max_statements">0</property>
        <property name="hibernate.c3p0.preferredTestQuery">select 1;</property>

    </session-factory>
</hibernate-configuration>

但是过了一段时间我的解析器停止了,我得到了这个:

окт 25, 2019 12:44:59 AM org.hibernate.engine.jdbc.spi.SqlExceptionHelper logExceptions
WARN: SQL Error: 0, SQLState: 08006
окт 25, 2019 12:44:59 AM org.hibernate.engine.jdbc.spi.SqlExceptionHelper logExceptions
ERROR: Ошибка ввода/ввывода при отправке бэкенду
окт 25, 2019 12:44:59 AM org.hibernate.engine.jdbc.spi.SqlExceptionHelper logExceptions
WARN: SQL Error: 0, SQLState: 08003
окт 25, 2019 12:44:59 AM org.hibernate.engine.jdbc.spi.SqlExceptionHelper logExceptions
ERROR: Соединение уже было закрыто

有什么方法可以解决这个问题?

java postgresql hibernate jdbc heroku-postgres
1个回答
0
投票

您的数据库连接即将关闭,您仅每3小时测试一次其有效性。空闲测试显然是not a good idea anyway

除非您在旧版环境中工作,否则应设置hibernate.c3p0.testconnectiononcheckout=true,这样您将始终获得有效的连接。

preferredTestQuery也是不必要的,如果您正在使用JDBC4驱动程序(并且希望是)。

© www.soinside.com 2019 - 2024. All rights reserved.