MySQL的JDBC连接失败错误

问题描述:

我们已经在AWS上部署REST API基于应用程序,有时下面的错误被抛出:MySQL的JDBC连接失败错误

产生的原因:com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: 最后从服务器成功收到的数据包是66,711,586, 毫秒前。成功发送到服务器的最后一个数据包是在66711,586毫秒前的 。比'wait_timeout'的值配置的服务器长 。在应用程序中使用之前,应考虑测试连接有效性,或者增加 服务器配置的客户端超时值,或者使用 连接器/ J连接属性'autoReconnect = true'来避免此 问题。在 sun.reflect.NativeConstructorAccessorImpl.newInstance0(本机方法) 〜[NA:1.7.0_85]在 sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57) 〜[NA:1.7.0_85]在 太阳.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 〜[na:1.7.0_85] at java.lang.reflect.Constructor.newInstance(Constructor.java:526) 〜[na:1.7.0_85] at com.mysql.jdbc.Util.handleNewInstance(Util.java:411) 〜[mysql-connector-java-5.1.27.jar:na] at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java: 1121) 〜[mysql-connector-java-5.1.27.jar:na] at com.mysql.jdbc.MysqlIO.send(MysqlIO.java:3988) 〜[mysql-connector-java-5.1.27.jar:na] at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java: 2598) 〜[mysql-connector-java-5.1.27.jar:na] at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2778) 〜[mysql-connector-java-5.1.27。 jar:na] at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2819) 〜[mysql-connector-java-5.1.27.jar:na] at com.mysql.jdbc.ConnectionImpl.setAutoCommit (ConnectionImpl.java:5346) 〜[mysql-connector-java-5.1.27.jar:na] at org.apache.commons.dbcp.DelegatingConnection.setAutoCommit(DelegatingConnection.java:371) 〜[commons-dbcp -1.4.jar:1.4 ] at org.apache.commons.dbcp.PoolingDataSource $ PoolGuardConnectionWrapper.setAutoCommit(PoolingDataSource.java:328) 〜[commons-dbcp-1.4.jar:1.4] at org.hibernate.engine.transaction.internal.jdbc。 JdbcTransaction.doBegin(JdbcTransaction.java:72) 〜[休眠核-4.2.7.Final.jar:4.2.7.Final] ... 90个共同帧 省略

此错误是随机引发而不是针对任何特定的API。

这就是在database.xml

<beans:property name="hibernateProperties"> 
      <beans:props> 
       <beans:prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect 
       </beans:prop> 
       <beans:prop key="hibernate.current_session_context_class">thread</beans:prop> 
       <beans:prop key="hibernate.show_sql">false</beans:prop> 
       <beans:prop key="maxwait">10000</beans:prop> 
       <beans:prop key="maxidle">25</beans:prop> 
       <beans:prop key="minidle">5</beans:prop> 
      </beans:props> 
</beans:property> 

任何建议,可以理解的配置。

感谢, Gayithri

这是因为您无法连接到数据库服务器。变量wait_timeout表示在杀死空闲连接之前MySQL将等待的时间。检查您的网络环境。

错误日志已经告诉您为什么以及如何解决问题。去试试吧。