Kettle表输出报关闭的连接问题的解决方法

5 篇文章 0 订阅
3 篇文章 0 订阅

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

说明

并不是所有的这样的错误都是驱动版本问题,请大家在遇到时逐一排除。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值