gpt4 book ai didi

java - 将 mariaDB 客户端与 MySQL 数据库集成的问题

转载 作者:行者123 更新时间:2023-12-02 19:19:08 26 4
gpt4 key购买 nike

我正在运行一个使用 MySQL 作为数据库服务器的 java 应用程序。 DB 是 AWS RDS。 MySQL 连接器是在 GNU/GPL 下发布的,因此必须用更宽松的东西代替它。 Maria DB 客户端声称兼容。但是自从使用 MariaDB 客户端以来,我们在数据库密集型 Activity 期间看到了以下间歇性问题:

Excption:-
SEVERE: Servlet.service() for servlet [dispatcher] in context with path [/Projectname] threw exception [Request processing failed; nested exception is org.springframework.transaction.CannotCreateTransactionException: Could not open Hibernate Session for transaction; nested exception is org.hibernate.exception.JDBCConnectionException: Unable to acquire JDBC Connection] with root cause
java.sql.SQLNonTransientConnectionException: (conn=1530488) Connection is closed
at org.mariadb.jdbc.internal.util.exceptions.ExceptionFactory.createException(ExceptionFactory.java:73)
at org.mariadb.jdbc.internal.util.exceptions.ExceptionFactory.create(ExceptionFactory.java:187)
at org.mariadb.jdbc.internal.protocol.AbstractQueryProtocol.cmdPrologue(AbstractQueryProtocol.java:1940)

Caused by: org.hibernate.exception.JDBCConnectionException: Unable to acquire JDBC Connection
at org.hibernate.exception.internal.SQLExceptionTypeDelegate.convert(SQLExceptionTypeDelegate.java:48)
at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:42)
at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:113)

Caused by: java.sql.SQLNonTransientConnectionException: Could not connect to address=(host=XXXXXXXXXX)(port=3306)(type=master) : (conn=1530487) could not load system variables
at org.mariadb.jdbc.internal.util.exceptions.ExceptionFactory.createException(ExceptionFactory.java:73)
at org.mariadb.jdbc.internal.util.exceptions.ExceptionFactory.create(ExceptionFactory.java:192)
at org.mariadb.jdbc.internal.protocol.AbstractConnectProtocol.connectWithoutProxy(AbstractConnectProtocol.java:1372)

我已尝试将 time_waitmax_allowed_pa​​cket 增加到允许的最大值,但问题仍然存在。

版本:-MySQL - 5.7.26MariaDB 连接器 - 2.6.2

最佳答案

刚刚遇到这个,找到了答案。在我这边,这是针对 Aurora 1 MySQL DB(相当于 5.6)的。

根据 Diego Dupin 在 https://jira.mariadb.org/browse/CONJ-824 :

only good solution is to use option `usePipelineAuth=false&useBatchMultiSend=false`

因此您的数据库连接字符串可能如下所示:jdbc:mysql://127.0.0.1:3307/mydbname?usePipelineAuth=false&useBatchMultiSend=false

更多详情:

Aurora proxy has a known race condition issue that results in skipping other 
queries in proxy buffer. connection might be in hang waiting for query response.
During authentication, socket has a timeout, that will result throwing the error
you describe.

So if `usePipelineAuth` or `useBatchMultiSend` is enable, it might work ... or not.
All pipeline options (`usePipelineAuth` and `useBatchMultiSend`) must be disabled when using aurora.
Problem has been reported to aurora a few times without correction.

关于java - 将 mariaDB 客户端与 MySQL 数据库集成的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63283846/

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