hicaricp pool:No operations allowed after connection closed以及Connection is not available错误处理

场景:

输入:一个大的json数组,将每个数组中的对象插入到数据库中(这个大的json数组中有129个对象)

问题:

未使用批量插入时,使用的是spring boot 2.2.0,spring data jpa,默认使用hikari cp连接池

hikariPool报错:

HikariPool-1 - Failed to validate connection com.mysql.jdbc.JDBC4Connection@3e471d67

(No operations allowed after connection closed.).

Possibly consider using a shorter maxLifetime value.

以及

HikariPool-1 - Connection is not available, request timed out after 30049ms.

发现其都是在插入129个对象的时候发生

 

原因:

第一个错误:No operations allowed after connection closed,异常的原因是mysql服务器主动关闭了连接(mysql参数 wait-timeout),而客户端还在用那个连接去操作。所以其提示我们把hicariCP连接池的maxLifetime时间调整为短语mysql的max-timeout,这样再连接被mysql服务器断开之前,连接池自己关闭此连接,重新生成一个新的连接。这个错误是正常的情况说明。

第二个错误:Connection is not available,其产生的原因就是connectionTimeout = 30,30秒内一个请求还没有获取到connection,于是报错。

猜测就是插入的时候,使用了多个connection,造成connection不够用造成的

 

解决方法:

在sping data jpa中实现批量插入

业务代码:

List<Hospital> data =JSON.parseArray(msgBody, Hospital.class);

hospitalRepository.saveAll(data);

配置:(重要

spring.jpa.properties.hibernate.jdbc.batch_size=150


配置了druid查看一下

参考:spring data jpa开启批量插入、批量更新

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]和\[2\]中提到的异常"jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed."是由于连接关闭后仍然执行了数据库操作引起的。引用\[3\]中解释了这个异常的原因,即MySQL默认空闲8小时没有操作会自动断开连接。在C3P0连接池中,如果连接空闲超过8小时,MySQL会断开连接,但C3P0并不知道该连接已经失效。当有客户端请求连接时,C3P0会提供这个失效的连接,从而导致上述异常的出现。 解决这个问题的方法是在Spring Boot的application.properties文件中增加DBCP配置。DBCP是Apache Commons DBCP连接池的一种实现,可以用来管理数据库连接。通过配置DBCP的相关参数,可以避免连接空闲超过8小时被MySQL断开的问题,从而解决上述异常。 请注意,具体的DBCP配置参数可能因使用的数据库和连接池的版本而有所不同。你可以根据自己的需求和环境进行相应的配置。 #### 引用[.reference_title] - *1* *3* [解决MySQLNonTransientConnectionException的问题](https://blog.csdn.net/wwwzhouzy/article/details/118710071)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [关于java.sql.SQLNonTransientConnectionException: No operations allowed after connection closed.的解决方案](https://blog.csdn.net/weixin_62338217/article/details/127405066)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值