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更换原来的驱动。 
测试,问题被解决。

说明
并不是所有的这样的错误都是驱动版本问题,请大家在遇到时逐一排除。
--------------------- 
作者:孤独的狼 
来源:CSDN 
原文:https://blog.csdn.net/zhaizhisheng/article/details/50580302 
版权声明:本文为博主原创文章,转载请附上博文链接!

你可能感兴趣的:(kettle)