java - Grails -- PooledConnection 已经关闭

标签 java oracle tomcat grails web

我在我的项目中使用 grails 2.3.11 和 Oracle 数据库。

我的数据库有问题。 异常:

ERROR (org.hibernate.util.JDBCExceptionReporter) - [99824F7C5386E5A40F94939FF36481FE | admin] - PooledConnection has already been closed.

运行以下代码时出现错误:

@NotTransactional
@Cacheable
def findSmth(String Id) {
     //Some logic here

    Employee.findWhere(company: company, employee: employee)
}

这段代码被重复执行,在某些迭代中出现错误。

注意:我使用多个数据源。错误发生在具有以下数据源的数据库中:

dataSource_employee_ro {
    dbCreate = 'validate'
    dialect = org.hibernate.dialect.Oracle10gDialect
    driverClassName = "oracle.jdbc.driver.OracleDriver"
    url = 'jdbc:oracle:thin:@(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = ****)(PORT = 2001))(FAILOVER = true)(LOAD_BALANCE = on)(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME = ****)(FAILOVER_MODE = (TYPE=select) (METHOD=basic) (RETRIES=10) (DELAY=3))))'
    username = '****'
    password = '******'
    readOnly = true
    properties {
        maxActive = 10
        maxIdle = 5
        minIdle = 1
        initialSize = 8
        testOnBorrow = true
        testWhileIdle = true
        testOnReturn = false
        validationQuery = "SELECT 1 FROM dual"
    }
    domainSchema = '*****'
}

即使我设置了“isPooled = false”(它看起来像“连接已经关闭”),也会出现异常。

我不知道如何摆脱这个错误。 谁能帮我?谢谢。

最佳答案

我前段时间遇到了同样的问题,问题是因为我在服务中运行一个方法,该服务是事务性的,而我有另一个线程运行数据库进程,所以当事务性方法结束时,事务关闭与数据库的连接。

无论如何,我不明白您为什么要在数据库的 findBla 方法中使用非事务标记。该方法应该从服务中调用,并且应该是事务性的。因此无需将其标记为非事务性。

希望我对您有所帮助:)

关于java - Grails -- PooledConnection 已经关闭,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36302362/

相关文章:

java - mybatis spring ref 光标映射

asp.net - 测试 Oracle 存储过程的最简单方法

tomcat - 将设置 : in context. xml 从 Tomcat 9 迁移到 Wildfly 14.0.1 Final

java - 凯撒密码 java 我的方式,不起作用

java - 无法理解在 IntStream 上使用 collect()

java - 构建远程代理时,Java 中合适的术语是什么?

java - Hibernate关联表映射

tomcat - 如何使 Tomcat 与 META-INF/context.xml 中定义的 TomcatInstrumentableClassLoader 以及 WEB-INF/lib/spring-instrument-tomcat.jar 一起工作

java - Liferay:从属性文件中获取 portal.normal.vm 中的 URL

java - 链接的java列表