gpt4 book ai didi

java - 如何为c3p0/hibernate配置查询超时阈值

转载 作者:行者123 更新时间:2023-11-29 14:02:36 24 4
gpt4 key购买 nike

我有一个使用 Hibernate 3、c3p0 和 spring 2.5.6 的应用程序。我们有一个配置为与 postgres 数据库对话的数据源。在应用程序服务器和数据库之间引入防火墙之前,一切都运行良好。我们在尝试与数据库通信时间歇性地收到 java.net.SocketTimeoutException: Read Timed Out 错误。

我们认为防火墙的开销导致数据库响应延迟。我们想通过增加查询在被视为超时之前应等待多长时间的阈值来验证这一点(如果可能的话)。这是一个堆栈跟踪片段

org.postgresql.util.PSQLException: An I/O error occured while sending to the backend.
at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:218)
at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:451)
at org.postgresql.jdbc2.AbstractJdbc2Statement.executeWithFlags(AbstractJdbc2Statement.java:350)
at org.postgresql.jdbc2.AbstractJdbc2Statement.executeQuery(AbstractJdbc2Statement.java:254)
at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.executeQuery(NewProxyPreparedStatement.java:76)
at org.hibernate.jdbc.AbstractBatcher.getResultSet(AbstractBatcher.java:208)
at org.hibernate.loader.Loader.getResultSet(Loader.java:1808)
at org.hibernate.loader.Loader.doQuery(Loader.java:697)
at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:259)
at org.hibernate.loader.Loader.loadEntity(Loader.java:1881)
... 35 more
Caused by: java.net.SocketTimeoutException: Read timed out
at java.net.SocketInputStream.socketRead0(Native Method)
at java.net.SocketInputStream.read(Unknown Source)
at org.postgresql.core.VisibleBufferedInputStream.readMore(VisibleBufferedInputStream.java:135)
at org.postgresql.core.VisibleBufferedInputStream.ensureBytes(VisibleBufferedInputStream.java:104)
at org.postgresql.core.VisibleBufferedInputStream.read(VisibleBufferedInputStream.java:73)
at org.postgresql.core.PGStream.ReceiveChar(PGStream.java:259)
at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:1166)
at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:192)
... 44 more

最佳答案

这与 Hibernate 或 C3P0 无关; JDBC 驱动程序超时。

如果您使用的是 8.4 或更高版本,请尝试设置 socketTimeout在您的连接字符串中设置为更高的值(甚至禁用它时为零)。

关于java - 如何为c3p0/hibernate配置查询超时阈值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1510265/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com