Grails - PooledConnection已经关闭

时间:2016-03-30 07:31:46

标签: java oracle tomcat grails web

我在我的项目中使用grails 2.3.11和Oracle DB。

我的数据库有问题。 例外:

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'(它看起来像“连接已经关闭”),也会出现异常。

我无法弄清楚如何摆脱这个错误。 谁能帮我?感谢。

1 个答案:

答案 0 :(得分:0)

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

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

我希望我有所帮助:)