4

我遇到了来自 Spring Boot 应用程序与 D1 Google CloudSQL Server 通信的间歇性连接错误,这里描述的配置设置为HikariCP MySQL 设置

我想知道是否有人以前遇到过这种情况。

我已阅读此处发布的常见问题解答Hikari 常见问题解答,我想知道我的默认 idleTimeout 和 maxLifeTime(30 分钟)设置是否有问题;服务器上的 wait_timeout 和 interactive_timeout 都设置为默认 28800 秒(8 小时)。

常见问题解答说这两个设置应该比服务器设置少大约一分钟,但是如果我在 30 分钟后失去连接,我不太明白将 maxLifeTime 提高到 7hrs 59mins 会如何改善这种情况。

有人有什么建议吗?

编辑的堆栈跟踪:

时不时得到这些

org.springframework.security.authentication.InternalAuthenticationServiceException: Could not get JDBC Connection; nested exception is java.sql.SQLException: Timeout after 30018ms of waiting for a connection.
    at org.springframework.security.authentication.dao.DaoAuthenticationProvider.retrieveUser(DaoAuthenticationProvider.java:110)
    at org.springframework.security.authentication.dao.AbstractUserDetailsAuthenticationProvider.authenticate(AbstractUserDetailsAuthenticationProvider.java:132)
    at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:156)
    at org.springframework.security.authentication.ProviderManager.authenticate(ProviderManager.java:177)
...
Caused by: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is java.sql.SQLException: Timeout after 30023ms of waiting for a connection.
    at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:80)
 ....
 Caused by: java.sql.SQLException: Timeout after 30023ms of waiting for a connection.
    at com.zaxxer.hikari.pool.HikariPool.getConnection(HikariPool.java:208)
    at com.zaxxer.hikari.HikariDataSource.getConnection(HikariDataSource.java:108)
    at org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:111)
    at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:77)
    ... 59 common frames omitted

    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:630)
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:695)
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:727)
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:737)
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:787)

休眠搜索:

2015-02-17 10:34:17.090  INFO 1 --- [ entityloader-2] o.h.s.i.SimpleIndexingProgressMonitor    : HSEARCH000030: 31050 documents indexed in 1147865 ms
2015-02-17 10:34:17.090  INFO 1 --- [ entityloader-2] o.h.s.i.SimpleIndexingProgressMonitor    : HSEARCH000031: Indexing speed: 27.050219 documents/second; progress: 99.89%
2015-02-17 10:41:59.917  WARN 1 --- [ntifierloader-1] com.zaxxer.hikari.proxy.ConnectionProxy  : Connection com.mysql.jdbc.JDBC4Connection@372f2018 (HikariPool-0) marked as broken because of SQLSTATE(08S01), ErrorCode(0).

com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

The last packet successfully received from the server was 1,611,087 milliseconds ago.  The last packet sent successfully to the server was 927,899 milliseconds ago.

我认为目前索引并不是特别快,因为我没有使用预测。该过程大约需要 30 分钟才能执行。

在此处输入图像描述

谢谢

4

1 回答 1

1

这里可能有几件事。首先,应用层和数据库层之间的网络基础设施(防火墙、负载平衡器等)可以强加自己的连接超时,而不管 MySql 设置如何。

索引失败表明连接在池外大约 27 分钟,并且在发生该失败时没有任何 SQL 活动。

其次,特别是关于“无法获得 JDBC 连接”错误,您可能遇到了Cloud SQL 连接限制

我推荐三件事。一,确保您使用的是最新的 HikariCP (2.3.2) 和最新的 MySql Connector/J 驱动程序 (5.1.34)。二,为 com.zaxxer.hikari 包启用 DEBUG 级日志记录。HikariCP 调试日志不是“闲聊”,而是每 30 秒记录一次池统计信息(有时在故障情况下会更详细)。最后,尝试将其设置maxPoolSize为更小的值(除非已经设置为默认值),然后设置maxLifeTime为 15 或 20 分钟(1200000 毫秒)。

如果错误再次发生,请在失败时发布包含 HikariCP 调试日志的更新日志。此外,请随时在 Github 上打开跟踪问题,因为更大的日志等在那里更容易。

于 2015-02-17T15:22:30.083 回答