Kettle表输出报关闭的连接问题的解决方法
最近在使用Kettle的时候表输出有时候会报一个错误 关闭的连接在网上查了半天都没有找到解决办法
现在记录一下解决过程以备后用。
软件环境
-Oracle 11g R2
-Kettle 5.0.1
-JDK 1.6
-Oracle Driver OJDBC14.jar
错误日志
ERROR (version v2.0, build 1 from 2014-09-30 16.48.55 by Admin) : Because of an error, this step can't continue:
2016/01/21 04:05:28 - get_core - ERROR (version v2.0, build 1 from 2014-09-30 16.48.55 by Admin) : org.pentaho.di.core.exception.KettleDatabaseException:
2016/01/21 04:05:28 - get_core - Error performing rollback on connection
2016/01/21 04:05:28 - get_core - 关闭的连接
2016/01/21 04:05:28 - get_core -
2016/01/21 04:05:28 - get_core - at org.pentaho.di.core.database.Database.rollback(Database.java:759)
2016/01/21 04:05:28 - get_core - at org.pentaho.di.core.database.Database.rollback(Database.java:739)
2016/01/21 04:05:28 - get_core - at org.pentaho.di.trans.steps.tableoutput.TableOutput.writeToTable(TableOutput.java:395)
2016/01/21 04:05:28 - get_core - at org.pentaho.di.trans.steps.tableoutput.TableOutput.processRow(TableOutput.java:128)
2016/01/21 04:05:28 - get_core - at org.pentaho.di.trans.step.RunThread.run(RunThread.java:60)
2016/01/21 04:05:28 - get_core - at java.lang.Thread.run(Thread.java:744)
2016/01/21 04:05:28 - get_core - Caused by: java.sql.SQLException: 关闭的连接
2016/01/21 04:05:28 - get_core - at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)
2016/01/21 04:05:28 - get_core - at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:146)
2016/01/21 04:05:28 - get_core - at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:208)
2016/01/21 04:05:28 - get_core - at oracle.jdbc.driver.PhysicalConnection.rollback(PhysicalConnection.java:1142)
2016/01/21 04:05:28 - get_core - at org.pentaho.di.core.database.Database.rollback(Database.java:751)
2016/01/21 04:05:28 - get_core - ... 5 more
问题分析
表面上看是在rollback的时候连接已经关闭了,但是为什么同样的数据有时候就不报错呢,那么问题应用就是在做正常表输出的时候已经发生了异常(连接关闭)然后被catch
到然后再执行rollback但是在执行rollback前程序只判断了连接是否为空并没有判断连接是否关闭,这就会出现以上的错误信息。
解决办法
通过以上的分析可以推断程序应该不会有问题,另外大家都知道在跨网段的时候一段时候不用Oracle会自动断开连接,但是本案例是正在向数据库中写数据是出现的错误。那
只有这样几种可能了
-1、网络不稳定
-2、Oracle 连接资源耗尽
-3、Oracle驱动有问题
通过了解第一种和第二种问题都被排除,最后看了一下使用的Oracle驱动版本为OJDBC14确实有点老了。在Oracle的Home目录下面找到JDBC目录然后将OJDBC6c更换原来的驱动。
测试,问题被解决。
说明
并不是所有的这样的错误都是驱动版本问题,请大家在遇到时逐一排除。