当ajax访问后台服务器端时报500 Internal Server Error,直接访问该controller方法时报java.sql.SQLRecoverableException: IO Error: Connection reset原因:当数据库连接池中的连接被创建而长时间不使用的情况下,...
![](https://oss.womengda.net/imgfile/2310/1ER060R39C0-42M1.jpg)
当ajax访问后台服务器端时报500 Internal Server Error,直接访问该controller方法时报java.sql.SQLRecoverableException: IO Error: Connection reset
原因:
当数据库连接池中的连接被创建而长时间不使用的情况下,该连接会自动回收并失效,但客户端并不知道,在进行数据库操作时仍然使用的是无效的数据库连接,这样,就导致客户端程序报“ java.sql.SQLException: Io 异常: Connection reset” 或“java.sql.SQLException 关闭的连接”异常。
解决办法:
在配置数据源后面加上
<property name="validationQuery" value="select * from dual"/>
配置后,客户端在使用一个无效的连接时会先对该连接进行测试,如果发现该连接已经无效,则重新从连接池获取有效数据库连接来使用。
解决思路是Connection Reset的原因有可能有以下几种原因:
1.配置的数据连接池的连接数不够用;
2.数据库的连接池中的连接,长时间不用,数据库主动断开连接,而客户端不知道,在用的时候仍然拿到的是无效的连接;
分别对应以上的两种猜想的原因,进行处理:
1.配置连接池的最大、最小、空闲连接数等;
2.配置对连接池里的连接进行有效性检查,如,配置有效性连接检查sql语句,配置是否进行有效性检查等;
本文标题为:ajax请求服务器时在控制台500 Internal Server Error,java.sql.SQLRecoverableException: IO Error: Connection reset
![](/xwassets/images/pre.png)
![](/xwassets/images/next.png)
- Spring Bean的8种加载方式总结 2023-06-23
- java – 在数据库中存储BitSet数组的最佳方法? 2023-10-31
- Java网络编程之简易聊天室的实现 2023-06-16
- MybatisPlus查询条件为空字符串或null问题及解决 2023-02-05
- SpringBoot面试突击之过滤器和拦截器区别详解 2023-06-16
- MybatisPlus分页查询与多条件查询介绍及查询过程中空值问题的解决 2023-06-10
- arthas jprofiler做复杂链路的调用分析 2022-12-11
- JSP技术实现动态页面到静态页面的方法 2023-08-02
- spring boot教程之IDEA环境下的热加载与热部署 2023-05-08
- springcloud 整合 openfeign的方法 2023-05-18