问题现象
用
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
操作提交。