spring - Tomcat dbcp removeAbandoned问题

标签 spring tomcat jdbc tomcat-dbcp

有人可以解释一下如何正确使用 removeAbandoned 属性吗? 问题是,我们有在事务中运行的服务方法(应用@Transactional)。例如,正文可以是 1000 条选择语句后跟 1000 条插入语句。 removeAbandoned 属性设置为 60 秒。现在,如果 1000 条插入语句的执行时间超过 60 秒,它将为下一个 db 语句抛出异常“连接已关闭”。为什么会发生这种情况以及如何克服这种情况?如果我删除 removeAbandoned 属性,则一切正常。这是我的 dbcp 配置。

db.initialSize=5
db.maxActive=150
db.minIdle=0
db.maxIdle=8
db.defaultAutoCommit=false
db.defaultTransactionIsolation=-1
db.maxWaitMillis=3000
db.timeBetweenEvictionRunMillis=1000
db.minEvictableIdleTimeMillis=1000
db.testOnBorrow=true
db.testOnReturn=false
db.testWhileIdle=false
db.removeAbandoned=true
db.removeAbandonedTimeout=60
db.poolPreparedStatements=true
db.validationQuery=select 1

通过使用这些属性,我们正在构建数据源。如果我在这里做错了什么,请纠正我。我假设这个服务在哪里被调用,它打开一个连接并执行 db 语句,但它试图在 removeAbandonedTimeout 之后使用相同的连接?

最佳答案

这是removeAbondoned的正常行为,检查here .您需要检查您的要求和约束并进行相应的配置。如果执行花费那么多时间并且这是正确的实现,则调整配置(增加放弃超时或完全删除它)。

例如,这对于夜间作业和离线数据迁移过程来说可能很常见。如果有用户交互,我认为你需要考虑响应性,从而改变服务的实现。然后你可能需要将它分离到不同的服务或调整内部的 SQL 或删除一些不必要的调用,但保持超时配置。

关于spring - Tomcat dbcp removeAbandoned问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48678096/

相关文章:

java - 在生产中拒绝OAuth2服务的访问 token -它在以前工作,刚刚开始失败。没有代码更改

sql-server - Solr 4.5 与 Tomcat 8 DataImportHandler 与 MSSQL 2008 R2

java - 如何从池中删除无效的数据库连接

java - 如何诊断 SQL Server View 和 JDBC 的性能问题

java - 是否有更友好的 BeanCreationException/ApplicationContext 加载问题 View

java - 如何从客户端桌面应用程序向服务器端 Spring 应用程序发出请求?

java - 如何更新 JTable View

java - 当过程不停止时,Java SQL 异常不显示 Oracle 异常

java - 如何解析在html请求中发送的java中的javascript对象?

java - 在 JAVA 中使用注释加载启动