DBA:临时表游标未释放导致回滚段空间不足
这篇论坛文章(赛迪网技术社区)根据笔者在工作中遇到的临时表游标未释放导致回滚段空间不足的错误现象及解决方法进行详尽的介绍,更多内容请参考下文: L+|$F)?7W/p一大早,突然收到生产系统报出多个ORA-01650错误,报回滚段空间不足。
jaS Td$Vp8s8cf
先分析一下相关背景。产生报错的程序是一个数据处理模块,每天会将其他系统传过来的平面文件中的内容处理后放入数据库中,事务量很大。我们的系统是9i,划分了16个回滚段,其中两个大的batch回滚段,每个batch回滚段有6G的足够空间。而数据处理模块会在事务中指定使用BATCH1。
.u5?dTdt3K
9i#W e&{@
再分析报错的模块。检查相关的数据事务处理部分,由于业务需要保持数据的一致性,需要处理完1个文件后才能提交,中间如果出错就要全部回滚。经过确认,这部分代码有很长时间没有做改动了。然后再确认数据量,可以确认,今天(周五)是一周之内文件内容最少的一天。也就是说,如果由于数据量引起错误,其他时间的概率应该更大。
h%lM1r!J K
但是,有一点需要注意。指定回滚段是针对事务的,不是针对回滚段。也就是说,我们可以指定某个事务只使用某个回滚段,但是不能保证这个回滚段只被这个事务事务。当一个事务申请使用回滚段时,如果没有自己指定,oracle就会根据当时的各个回滚段的使用情况,分配一个最合适的回滚段给这个事务使用。因此,报回滚段空间不足的事务可能不一定就是导致回滚段空间不足的事务。还有一种可能就是,事务所指定的回滚段被其他事务所占用了。
于是我们就检查是否还有其他事务占用了该回滚段。 `AfTT];A-`5X
u:jZ^;W%o!F-|{
SELECT s.sid, s.username, s.osuser, s.machine, s.program,