问题现象
用 orato8a 导出 1.2T 数据,导出 290G 左右数据就无法写入。试过全表导出和 query
方式导出,都出现了同样的现象。
orato8a 报错:
ERROR CODE = 1555
ORA-01555:snapshot too old:rollback segment number 614 with name "_SYS
SMU614_278740291$" too small
export columns:60
export rows:645661015
export time:4 hours 21 min 6 sec
process ok!
原因分析
问题是当单次查询导出数据量过大,且其它应用 DML 操作提交过多时,oracle 的
快照失效引起。
解决方案
orato8a:
1) 使用--table_name 参数,加大--parallel 并发数,以减少查询导出时间;
2) 使用--query 参数,带 where 过滤,以减少查询导出时间。
oracle 配置
3) 增加 UNDO 表空间大小;
4) 增加 UNDO_RETENTION 时间,默认为 15 分钟。
现场其它访问 oracle 的应用
1) 避免频繁的 DML 操作提交。