datax-ORA-01555错误

问题描述

https://www.cndba.cn/hbhe0316/article/106582
Datax抄写的时候发现日志抛出ORA-01555错误。

问题现象https://www.cndba.cn/hbhe0316/article/106582

https://www.cndba.cn/hbhe0316/article/106582
https://www.cndba.cn/hbhe0316/article/106582
经DataX智能分析,该任务最可能的错误原因是:
com.alibaba.datax.common.exception.DataXException: Code:[DBUtilErrorCode-07], Description:[读取数据库数据失败. 请检查您的配置的 column/table/where/querySql或者向 DBA 寻求帮助.].  - 执行的SQL为:  具体错误信息为:java.sql.SQLException: ORA-01555: snapshot too old: rollback segment number 8 with name "_SYSSMU8_100119489$" too small

        at com.alibaba.datax.common.exception.DataXException.asDataXException(DataXException.java:26)
        at com.alibaba.datax.plugin.rdbms.util.RdbmsException.asQueryException(RdbmsException.java:93)
        at com.alibaba.datax.plugin.rdbms.reader.CommonRdbmsReader$Task.startRead(CommonRdbmsReader.java:220)
        at com.alibaba.datax.plugin.reader.oraclereader.OracleReader$Task.startRead(OracleReader.java:110)
        at com.alibaba.datax.core.taskgroup.runner.ReaderRunner.run(ReaderRunner.java:57)
        at java.lang.Thread.run(Thread.java:748)

分析过程

https://www.cndba.cn/hbhe0316/article/106582
https://www.cndba.cn/hbhe0316/article/106582 https://www.cndba.cn/hbhe0316/article/106582
ORA-01555 快照过旧,是数据库中很常见的一个错误,比如当我们的事务需要使用undo来构建CR块的时候,而此时对应的undo已经不存在了,这个时候就会报ORA-01555的错误。
    ORA-01555错误在Oracle 8i及之前的版本最多。从9i开始的undo自动管理,至现在的10g、11g中的undo auto tuning,使得ORA-01555的错误越来越少。但是这个错误,仍然不可避免。
(1)、SQL语句执行时间太长,或者undo表空间过小,或者事务量过大,或者过于频繁的提交,导致执行SQL过程中进行一致性读时,SQL执行后修改的前镜像(既UNDO数据)在UNDO表空间中已经被覆盖,不能构造一致性读块(CR blocks)。这种情况最多。
    (2)、SQL语句执行过程中,访问到的块,在进行延迟块清除时,不能确定该块的事务提交时间与SQL执行开始时间的先后次序。这种情况很少。

解决方案https://www.cndba.cn/hbhe0316/article/106582

https://www.cndba.cn/hbhe0316/article/106582
https://www.cndba.cn/hbhe0316/article/106582
(1)、增加UNDO表空间大小;
    (2)、增加undo_retention时间,默认只有15分钟;
    (3)、优化出错的SQL,减少查询的时间,首选方法;
    (4)、避免频繁的提交。

版权声明:本文为博主原创文章,未经博主允许不得转载。

Linux

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值