当前位置: 首页 > 知识库问答 >
问题:

使用jpa-hibernate高并发将无法获取JDBC连接

申屠昆
2023-03-14

当我在jpaHibernate期间遇到高并发时,项目运行一段时间后会报告“无法获取JDBC连接”错误。但是在我添加了hikari数据库连接池之后,问题就解决了。为什么会发生这种情况或者没有其他方法可以解决它?

共有1个答案

严宇
2023-03-14

这要看你之前用的是什么泳池。

HikariCP-maxLifeTime 默认值为 30 分钟。在此之后,连接将返回给DBMS,这通常会限制最大连接数。

DBCP 默认值没有限制。

如果您没有使用池,则如果您自己不使用,则没有人会关闭连接。

所以这可能就是你不再得到异常的原因。但是要注意,可能会留下内存泄漏。这意味着可能会有Hibernate会话存储在代码中的任何位置,这些会话永远不会被使用,也永远不会被关闭。

 类似资料:
  • 我有一个Hibernate和光数据源的Spring Boot项目。如果我使用注入的SessionFactory对象来获取会话对象,几天后,我会发现与数据库操作相关的任何方法都有这样的异常(只有重新启动才能解决这个问题): 似乎手动使用的会话使此问题。(我有类似的项目,具有相同的配置和功能,但没有注入SessionFactory和Session...我根本没有这样的问题) 应用程序. yaml: 数

  • 我们的项目中有Spring boot/Hibernate/MYSQL应用程序,并使用Hikari作为连接池。服务启动几分钟后,我们发现以下问题: org.springframework.web.util.嵌套异常:请求处理失败;嵌套异常org.springframework.dao.DataAccessResourceFailureExc0019:无法获取JDBC连接;嵌套异常org.hibern

  • 我通过动态创建具有以下属性的数据源来连接mysql数据库,它工作正常,但过了一段时间后,它一直给我错误“无法获取JDBC连接”。 它被托管在AWS和Tomcat环境中。DB是AWS的RDS。 更新: 原因:

  • 我正在运行一个带有Hibernate和Spring数据的Spring启动应用程序。我有以下方法: 当我第四次运行此方法时,我得到了无法获取 JDBC 连接异常。我怀疑当我调用存储过程“callEncrypt”时,Hibernate在作业完成后不会释放连接,因为如果我删除该行,应用程序就可以完美运行,无法手动关闭连接,因为Hibernate正在处理事务(并且没有理由这样做),所以我已经卡住了一段时间

  • 当我使用Japser报告生成报告时,我的Spring Boot工作正常。 我面临的问题是应用程序抛出Hibernate异常: 无法获取JDBC连接 在我多次生成报告后,我得到了这个错误。